﻿/*
  Zeus Design System v2 — Professional Upgrade
*/

:root {
  --bg:   #07090e;
  --bg-2: #0a0e17;
  --surface:   rgba(255,255,255,.038);
  --surface-2: rgba(255,255,255,.058);
  --surface-3: rgba(255,255,255,.082);
  --border:        rgba(255,255,255,.07);
  --border-strong: rgba(255,255,255,.14);
  --text:   #f0f4ff;
  --text-2: #8b9ab5;
  --text-3: #576177;
  --text-4: #3a4459;
  --blue:      #4f8eff;
  --blue-2:    #2f72f0;
  --blue-soft: rgba(79,142,255,.10);
  --green:      #12c995;
  --green-soft: rgba(18,201,149,.10);
  --amber:      #f5a623;
  --red:        #f16868;
  --font: "Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --mono: "Geist Mono",ui-monospace,"SF Mono",Menlo,monospace;
  --radius:     12px;
  --radius-sm:  8px;
  --pad:        20px;
}

html, body { background: var(--bg); }

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(ellipse 1400px 700px at 30% -15%,
      rgba(60,120,255,.08) 0%, transparent 65%),
    radial-gradient(ellipse 900px 600px at 80% 90%,
      rgba(18,200,150,.05) 0%, transparent 65%);
}

.card {
  background:
    linear-gradient(160deg,
      rgba(255,255,255,.045) 0%,
      rgba(255,255,255,.018) 100%) !important;
  border: 1px solid var(--border) !important;
  border-top-color: rgba(255,255,255,.12) !important;
  border-radius: var(--radius) !important;
  backdrop-filter: blur(14px) saturate(1.4);
  -webkit-backdrop-filter: blur(14px) saturate(1.4);
  box-shadow:
    0 1px 0  rgba(255,255,255,.055) inset,
    0 1px 3px rgba(0,0,0,.35),
    0 8px 32px rgba(0,0,0,.22) !important;
  transition: border-color .18s, box-shadow .18s, transform .18s;
}
.card:hover {
  border-color: var(--border-strong) !important;
  box-shadow:
    0 1px 0  rgba(255,255,255,.08) inset,
    0 2px 6px rgba(0,0,0,.4),
    0 12px 44px rgba(0,0,0,.28) !important;
  transform: translateY(-1px);
}
.card-head {
  color: var(--text-3) !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: .10em !important;
}

#sidebar {
  width: 248px !important;
  flex: 0 0 248px !important;
  background: rgba(5,7,12,.82) !important;
  border-right: 1px solid var(--border) !important;
}

.nav-item {
  padding: 7px 10px !important;
  border-radius: 8px !important;
  color: var(--text-3) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  transition: background .12s, color .12s, padding-left .12s !important;
  border: 1px solid transparent !important;
}
.nav-item:hover {
  background: var(--surface) !important;
  color: var(--text-2) !important;
  padding-left: 13px !important;
}
.nav-item.active {
  background: var(--blue-soft) !important;
  color: var(--blue) !important;
  border-color: rgba(79,142,255,.18) !important;
}
.nav-ico { color: var(--text-4) !important; }
.nav-item:hover .nav-ico { color: var(--text-3) !important; }
.nav-item.active .nav-ico { color: var(--blue) !important; }

#header {
  background: rgba(7,9,14,.75) !important;
  border-bottom: 1px solid var(--border) !important;
  backdrop-filter: blur(20px) !important;
  min-height: 60px !important;
}

.btn:active { transform: scale(.98) !important; }
.btn.primary, .btn-primary {
  background: linear-gradient(160deg, var(--blue), var(--blue-2)) !important;
  border-color: transparent !important;
  color: #fff !important;
  box-shadow: 0 4px 18px rgba(47,114,240,.35), 0 1px 0 rgba(255,255,255,.18) inset !important;
}
.btn.primary:hover, .btn-primary:hover {
  filter: brightness(1.08) !important;
}

.view-panel.active {
  animation: viewFadeIn .22s cubic-bezier(.22,.68,0,1.2) both !important;
}
@keyframes viewFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.1); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.2); }

#zeus-status-bar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  height: 30px;
  background: rgba(5,7,12,.92);
  border-top: 1px solid var(--border);
  backdrop-filter: blur(20px);
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 0 16px;
  z-index: 9999;
  font: 500 11px/1 var(--mono);
  color: var(--text-4);
}
#zeus-status-bar .sb-item { display: flex; align-items: center; gap: 5px; }
#zeus-status-bar .sb-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--text-4);
}
#zeus-status-bar .sb-dot.online { background: var(--green); box-shadow: 0 0 6px var(--green); }
#zeus-status-bar .sb-dot.pulse { animation: sbPulse 2s ease-in-out infinite; }
@keyframes sbPulse { 0%,100%{opacity:1} 50%{opacity:.4} }
#zeus-status-bar .sb-sep { width: 1px; height: 12px; background: var(--border-strong); }
#zeus-status-bar #sb-state { color: var(--text-2); font-weight: 600; }

#reminder-toast {
  position: fixed;
  top: 72px; right: 20px;
  width: 340px;
  background: linear-gradient(160deg,
    rgba(14,21,34,.97) 0%,
    rgba(10,14,23,.97) 100%);
  border: 1px solid rgba(79,142,255,.35);
  border-top-color: rgba(79,142,255,.6);
  border-radius: 14px;
  padding: 18px 20px 16px;
  z-index: 99999;
  box-shadow:
    0 0 0 1px rgba(79,142,255,.12),
    0 8px 32px rgba(0,0,0,.5),
    0 0 60px rgba(79,142,255,.08);
  display: none;
  animation: reminderPop .32s cubic-bezier(.22,.68,0,1.3) both;
}
#reminder-toast.show { display: block; }
@keyframes reminderPop {
  from { opacity: 0; transform: translateX(30px) scale(.94); }
  to   { opacity: 1; transform: translateX(0) scale(1); }
}
#reminder-toast .rt-header {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 11px;
}
#reminder-toast .rt-icon {
  width: 36px; height: 36px;
  border-radius: 10px;
  background: var(--blue-soft);
  border: 1px solid rgba(79,142,255,.25);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; flex-shrink: 0;
}
#reminder-toast .rt-title {
  font: 700 13.5px/1.2 var(--font);
  color: var(--text);
}
#reminder-toast .rt-time {
  font: 500 11px/1 var(--mono);
  color: var(--blue);
  margin-top: 3px;
}
#reminder-toast .rt-msg {
  font: 400 13px/1.55 var(--font);
  color: var(--text-2);
  margin-bottom: 14px;
  font-style: italic;
}
#reminder-toast .rt-actions { display: flex; gap: 8px; }
#reminder-toast .rt-btn {
  flex: 1;
  height: 32px;
  border-radius: 8px;
  border: 1px solid var(--border-strong);
  background: var(--surface-2);
  color: var(--text-2);
  font: 600 12px/1 var(--font);
  cursor: pointer;
  transition: all .12s;
}
#reminder-toast .rt-btn:hover { background: var(--surface-3); color: var(--text); }
#reminder-toast .rt-btn.snooze {
  background: var(--blue-soft);
  border-color: rgba(79,142,255,.3);
  color: var(--blue);
}
#reminder-toast .rt-btn.snooze:hover { background: rgba(79,142,255,.18); }
#reminder-toast .rt-close {
  position: absolute; top: 10px; right: 12px;
  width: 22px; height: 22px;
  border: none; background: none;
  color: var(--text-4); font-size: 16px;
  cursor: pointer; border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  transition: color .12s;
}
#reminder-toast .rt-close:hover { color: var(--text-2); }

.live-indicator {
  display: inline-flex; align-items: center; gap: 5px;
  font: 700 9.5px/1 var(--mono);
  letter-spacing: .1em; color: var(--green);
}
.live-indicator::before {
  content: "";
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 8px var(--green);
  animation: livePulse 1.8s ease-in-out infinite;
}
@keyframes livePulse { 0%,100%{opacity:1} 50%{opacity:.5} }

::selection { background: rgba(79,142,255,.3); color: var(--text); }

/* ═══════════════════════════════════════════════════════════
   MAAKER STYLE — grosse Zahlen, viel Luft, kein Lärm
   ════════════════════════════════════════════════════════════ */

/* Dashboard Hero — mehr Luft */
#zeus-hero { padding: 28px 0 20px; }

/* Greeting: klarer, grösser */
#dash-greeting {
  font-size: clamp(28px, 3vw, 42px) !important;
  font-weight: 800 !important;
  letter-spacing: -.03em !important;
  line-height: 1.05 !important;
}
#dash-greeting em { font-style: normal; color: var(--blue); }

/* Sub-Text leiser */
#dash-sub {
  color: var(--text-3) !important;
  font-size: 13.5px !important;
  margin-top: 5px;
}

/* Crypto Ticker: pill-style, kein Rahmen-Chaos */
#crypto-ticker {
  border-bottom: 1px solid var(--border);
  padding-bottom: 14px !important;
  margin-bottom: 4px;
}

/* Briefing Card — Hauptkarte muss atmen */
#view-dashboard > .dash-grid > .card:first-child {
  padding: 24px 28px !important;
}

/* Zahlen auf Cards: VIEL grösser à la Maaker */
.big-stat {
  font-size: clamp(44px, 5vw, 68px) !important;
  font-weight: 800 !important;
  letter-spacing: -.05em !important;
  line-height: .95 !important;
  font-variant-numeric: tabular-nums !important;
}
.big-stat-green { color: var(--green); }
.big-stat-blue  { color: var(--blue); }

/* Card-Kopf: kleiner, mehr Abstand nach unten */
.card .card-head {
  font-size: 10px !important;
  letter-spacing: .14em !important;
  margin-bottom: 14px !important;
  color: var(--text-4) !important;
}

/* Context Bar: sauber, kein Hintergrund */
#context-bar {
  padding: 8px 0 6px !important;
  gap: 6px !important;
}

/* Nav: section separator */
.nav-sep {
  height: 1px;
  background: var(--border);
  margin: 6px 10px;
}

/* Typografie: h-greet uniform */
.h-greet {
  font-size: clamp(26px, 3vw, 40px) !important;
  font-weight: 800 !important;
  letter-spacing: -.03em !important;
  line-height: 1.06 !important;
}
.h-greet em { font-style: normal; color: var(--blue); }

/* Stats auf Affiliate und anderen Views */
.aff-stat-val {
  font-size: 38px !important;
  font-weight: 800 !important;
  letter-spacing: -.03em !important;
  line-height: 1 !important;
}

/* Muted text: einheitlich */
.muted, .sub { color: var(--text-3) !important; }

/* Pills: clean */
.pill {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-radius: 99px !important;
  padding: 3px 10px !important;
  font-size: 11.5px !important;
  color: var(--text-3) !important;
}

/* Aktivitäts-Journal: schöner */
.activity-row, .journal-row {
  padding: 7px 0 !important;
  border-bottom: 1px solid rgba(255,255,255,.04) !important;
  font-size: 13px !important;
}

/* REMOVE: alle box-shadow auf body-pseudo */
body::after { display: none !important; }

/* Dash Briefing Hub — mehr Luft */
.brief-hub { padding: 4px 0 !important; }
.brief-main { font-size: 14px !important; line-height: 1.65 !important; color: var(--text-2) !important; }

/* Wetter: Temp-Zahl gross */
#dash-temp {
  font-size: 44px !important;
  font-weight: 300 !important;
  line-height: 1 !important;
  color: var(--text) !important;
}

/* Status Bar: bei Maaker immer unten, sehr slim */
#zeus-status-bar {
  font-size: 10.5px !important;
  letter-spacing: .04em !important;
}

/* ═══════════════════════════════════════════════════════════
   ZEUS DESIGN UPGRADE — visuell stärker, klarer, moderner
   ════════════════════════════════════════════════════════════ */

/* Hero: leuchtende Akzent-Linie oben */
#zeus-hero {
  border-top: 2px solid rgba(79,142,255,.35) !important;
  background:
    linear-gradient(135deg, rgba(10,24,52,.92) 0%, rgba(4,10,28,.96) 100%) !important;
  box-shadow:
    0 0 0 1px rgba(79,142,255,.08),
    0 4px 40px rgba(0,0,0,.4),
    inset 0 1px 0 rgba(79,142,255,.15) !important;
}

/* Greeting: subtiler Glow auf dem Namen */
#dash-greeting em {
  text-shadow: 0 0 28px rgba(79,142,255,.45);
}

/* Crypto Ticker: moderne Pill-Chips */
#crypto-list .pill {
  background: rgba(79,142,255,.08) !important;
  border-color: rgba(79,142,255,.18) !important;
  color: var(--text-2) !important;
  font-size: 11.5px !important;
  font-family: var(--mono) !important;
  transition: background .15s !important;
}
#crypto-list .pill:hover {
  background: rgba(79,142,255,.14) !important;
}

/* API Status Dots: im Settings sauber */
#api-status-list .api-row {
  font-size: 12.5px !important;
  font-weight: 500 !important;
  color: var(--text-2) !important;
}

/* Push/GPS Karte: Accent-Border oben */
#view-settings .card:has(#gps-status-dot) {
  border-top-color: rgba(79,142,255,.4) !important;
}

/* Header: GPS Badge */
#zeus-location-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 99px;
  background: rgba(18,201,149,.08);
  border: 1px solid rgba(18,201,149,.2);
  color: var(--green);
  font: 700 10.5px/1 var(--mono);
  letter-spacing: .04em;
}

/* Away-Badge im Header */
#zeus-away-badge {
  display: none;
  align-items: center;
  gap: 5px;
  padding: 3px 10px;
  border-radius: 99px;
  background: rgba(245,166,35,.08);
  border: 1px solid rgba(245,166,35,.25);
  color: var(--amber);
  font: 700 10.5px/1 var(--mono);
}
#zeus-away-badge.visible { display: inline-flex; }

/* Briefing: schöner Link-Style für die Zeus Aussage */
.brief-main p:first-child {
  font-size: 14.5px !important;
  line-height: 1.7 !important;
}

/* Schönere Trennlinie im Dashboard */
#context-bar {
  border-top: 1px solid rgba(255,255,255,.04) !important;
  border-bottom: 1px solid rgba(255,255,255,.04) !important;
  margin: 4px 0 !important;
  padding: 8px 0 !important;
}

/* Cards im Dashboard: subtiler linker Akzent für Typen */
#view-dashboard .card.col-12:first-child {
  border-left: 3px solid var(--blue) !important;
}

/* Verbindungs-Status 2-Spalten Grid */
#api-status-list {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 2px 12px !important;
}

/* ═══════════════════════════════════════════════════════════════
   ZEUS PREMIUM — JARVIS J27 LEVEL DESIGN SYSTEM
   Referenz: JARVIS J27 Dashboard (brain final.png, Dashboard 001.png)
   Ultra-dark, dichte Info-Karten, Glow-Ringe, Command-Center Feeling
   ═══════════════════════════════════════════════════════════════ */

/* ── FARB-SYSTEM UPGRADE ── */
:root {
  --bg:          #030508;
  --bg-2:        #060a12;
  --bg-3:        #080d18;
  --surface:     rgba(255,255,255,.032);
  --surface-2:   rgba(255,255,255,.052);
  --surface-3:   rgba(255,255,255,.075);
  --border:      rgba(255,255,255,.065);
  --border-strong: rgba(255,255,255,.13);
  --border-blue: rgba(37,136,255,.28);
  --text:        #eef3ff;
  --text-2:      #7f8fa8;
  --text-3:      #4a5570;
  --text-4:      #2e3a50;
  --blue:        #2f8fff;
  --blue-2:      #1a72e0;
  --blue-glow:   rgba(47,143,255,.18);
  --cyan:        #00d4e8;
  --cyan-soft:   rgba(0,212,232,.12);
  --green:       #00e5a0;
  --green-soft:  rgba(0,229,160,.10);
  --amber:       #ffb020;
  --amber-soft:  rgba(255,176,32,.10);
  --violet:      #a855f7;
  --violet-soft: rgba(168,85,247,.12);
  --red:         #ff4d6a;
  --gold:        #f5c842;
}

html, body {
  background: var(--bg) !important;
}

body::before {
  background:
    radial-gradient(ellipse 1600px 800px at 50% -20%,
      rgba(30,100,255,.07) 0%, transparent 60%),
    radial-gradient(ellipse 600px 400px at 85% 15%,
      rgba(0,212,232,.04) 0%, transparent 55%),
    radial-gradient(ellipse 400px 300px at 10% 80%,
      rgba(168,85,247,.03) 0%, transparent 55%) !important;
}

/* ── SIDEBAR JARVIS-STYLE ── */
#sidebar {
  background: rgba(3,5,10,.95) !important;
  border-right: 1px solid rgba(255,255,255,.05) !important;
  width: 240px !important;
  flex: 0 0 240px !important;
}

.brand-name {
  font-size: 16px !important;
  font-weight: 800 !important;
  letter-spacing: .18em !important;
  background: linear-gradient(135deg, #fff 0%, #4fa2ff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.nav-item {
  font-size: 12.5px !important;
  padding: 6px 10px !important;
  color: rgba(130,150,180,.7) !important;
  border-radius: 7px !important;
}
.nav-item:hover {
  background: rgba(47,143,255,.07) !important;
  color: rgba(180,205,240,.9) !important;
}
.nav-item.active {
  background: rgba(47,143,255,.12) !important;
  color: #60b0ff !important;
  border-color: rgba(47,143,255,.22) !important;
}
.nav-ico { font-size: 13px !important; }

/* ── CARDS JARVIS-STYLE ── */
.card {
  background: linear-gradient(160deg,
    rgba(255,255,255,.038) 0%,
    rgba(255,255,255,.014) 100%) !important;
  border: 1px solid rgba(255,255,255,.065) !important;
  border-top-color: rgba(255,255,255,.10) !important;
  border-radius: 11px !important;
  backdrop-filter: blur(20px) saturate(1.6) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.045),
    0 2px 8px rgba(0,0,0,.45),
    0 16px 48px rgba(0,0,0,.28) !important;
}
.card:hover {
  border-color: rgba(47,143,255,.22) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.07),
    0 2px 12px rgba(0,0,0,.5),
    0 0 0 1px rgba(47,143,255,.08),
    0 20px 60px rgba(0,0,0,.32) !important;
}

/* ── SECTION HEADINGS ── */
.h-greet {
  font-size: clamp(26px,2.1vw,36px) !important;
  font-weight: 750 !important;
  letter-spacing: -.025em !important;
  color: #eef3ff !important;
  line-height: 1.1 !important;
}
.h-greet em {
  font-style: normal !important;
  background: linear-gradient(135deg, #4fa2ff 0%, #00d4e8 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── DASHBOARD GREETING PREMIUM ── */
#dash-greeting {
  font-size: clamp(30px, 2.6vw, 44px) !important;
  font-weight: 750 !important;
  letter-spacing: -.03em !important;
  line-height: 1.1 !important;
}
#dash-greeting em {
  background: linear-gradient(135deg, #4fa2ff 0%, #00d4e8 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-style: normal !important;
}
#dash-sub {
  font-size: 13.5px !important;
  color: var(--text-2) !important;
  margin-top: 6px !important;
  letter-spacing: .01em;
}

/* ── ZEUS ORB PREMIUM GLOW ── */
#hero-orb {
  box-shadow:
    0 0 30px rgba(47,143,255,.55),
    0 0 80px rgba(47,143,255,.28),
    0 0 160px rgba(47,143,255,.12),
    inset 0 0 30px rgba(0,212,232,.18) !important;
}
#hero-orb-glow {
  background: radial-gradient(circle at 35% 35%,
    rgba(0,212,232,.25) 0%,
    rgba(47,143,255,.18) 40%,
    transparent 70%) !important;
}

/* ── ZIRKULÄRE PROGRESS RINGE (JARVIS-Style) ── */
.ring-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.ring-wrap svg { transform: rotate(-90deg); }
.ring-track { fill: none; stroke: rgba(255,255,255,.06); }
.ring-fill  { fill: none; stroke-linecap: round; transition: stroke-dashoffset .8s cubic-bezier(.4,0,.2,1); }
.ring-fill.blue   { stroke: #2f8fff; filter: drop-shadow(0 0 4px rgba(47,143,255,.6)); }
.ring-fill.cyan   { stroke: #00d4e8; filter: drop-shadow(0 0 4px rgba(0,212,232,.6)); }
.ring-fill.green  { stroke: #00e5a0; filter: drop-shadow(0 0 4px rgba(0,229,160,.6)); }
.ring-fill.amber  { stroke: #ffb020; filter: drop-shadow(0 0 4px rgba(255,176,32,.6)); }
.ring-fill.violet { stroke: #a855f7; filter: drop-shadow(0 0 4px rgba(168,85,247,.6)); }
.ring-fill.gold   { stroke: #f5c842; filter: drop-shadow(0 0 4px rgba(245,200,66,.6)); }
.ring-label {
  position: absolute;
  text-align: center;
  line-height: 1.2;
}
.ring-label .ring-pct {
  font-family: var(--mono);
  font-weight: 700;
  color: var(--text);
  display: block;
}
.ring-label .ring-sub {
  font-size: 9px;
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: .08em;
  display: block;
  margin-top: 1px;
}

/* Größen */
.ring-lg  { width: 96px;  height: 96px;  }
.ring-md  { width: 72px;  height: 72px;  }
.ring-sm  { width: 54px;  height: 54px;  }
.ring-lg  .ring-pct { font-size: 20px; }
.ring-md  .ring-pct { font-size: 16px; }
.ring-sm  .ring-pct { font-size: 13px; }

/* ── METRIC KACHEL mit Ring ── */
.kpi-ring-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 18px 14px;
  background: linear-gradient(160deg, rgba(255,255,255,.038), rgba(255,255,255,.012));
  border: 1px solid rgba(255,255,255,.065);
  border-top-color: rgba(255,255,255,.10);
  border-radius: 11px;
  backdrop-filter: blur(16px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 8px 32px rgba(0,0,0,.28);
  cursor: pointer;
  transition: border-color .18s, box-shadow .18s, transform .18s;
}
.kpi-ring-card:hover {
  border-color: rgba(47,143,255,.25);
  transform: translateY(-2px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06), 0 0 0 1px rgba(47,143,255,.1), 0 12px 40px rgba(0,0,0,.35);
}
.kpi-ring-card .kpi-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-3);
  text-align: center;
}

/* ── QUICK-STAT KACHELN (Zahlen-only) ── */
.qstat-card {
  padding: 18px 16px;
  text-align: center;
  cursor: pointer;
  background: linear-gradient(160deg, rgba(255,255,255,.038), rgba(255,255,255,.012));
  border: 1px solid rgba(255,255,255,.065);
  border-top-color: rgba(255,255,255,.10);
  border-radius: 11px;
  backdrop-filter: blur(16px);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04), 0 8px 32px rgba(0,0,0,.28);
  transition: border-color .18s, transform .18s, box-shadow .18s;
  position: relative;
  overflow: hidden;
}
.qstat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(47,143,255,.35), transparent);
  opacity: 0;
  transition: opacity .2s;
}
.qstat-card:hover { transform: translateY(-2px); }
.qstat-card:hover::before { opacity: 1; }
.qstat-card:hover { border-color: rgba(47,143,255,.22) !important; }
.qstat-card .qs-label {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 8px;
}
.qstat-card .qs-val {
  font-size: 36px;
  font-weight: 750;
  line-height: 1;
  font-family: var(--mono);
  margin-bottom: 4px;
}
.qstat-card .qs-sub {
  font-size: 10.5px;
  color: var(--text-3);
}
.qstat-card.blue  .qs-val { color: #4fa2ff; text-shadow: 0 0 20px rgba(79,162,255,.4); }
.qstat-card.amber .qs-val { color: #ffb020; text-shadow: 0 0 20px rgba(255,176,32,.4); }
.qstat-card.green .qs-val { color: #00e5a0; text-shadow: 0 0 20px rgba(0,229,160,.4); }
.qstat-card.violet .qs-val { color: #a855f7; text-shadow: 0 0 20px rgba(168,85,247,.4); }

/* ── RIGHT RAIL — ZEUS ARBEITET ── */
#right-rail {
  display: flex !important;
  flex-direction: column !important;
  background: linear-gradient(180deg, rgba(8,14,28,.98), rgba(5,9,18,.96)) !important;
  border-left: 1px solid rgba(47,143,255,.12) !important;
  width: 280px !important;
  flex: 0 0 280px !important;
}
/* Immer sichtbar — auch wenn body.dashboard-wide gesetzt ist */
body.dashboard-wide #right-rail {
  display: flex !important;
}
/* Dashboard-Breite anpassen da Right Rail immer sichtbar */
body.dashboard-wide #view-dashboard {
  max-width: 1100px !important;
}
.rail-sec-title {
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(120,150,190,.55);
  margin-bottom: 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(255,255,255,.07);
}
.rail-mission-card {
  background: linear-gradient(160deg, rgba(255,255,255,.035), rgba(255,255,255,.012));
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 9px;
  padding: 11px 12px;
  margin-bottom: 8px;
  transition: border-color .15s;
}
.rail-mission-card:hover { border-color: rgba(47,143,255,.2); }
.rail-mission-card .rmc-title {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  margin-bottom: 4px;
  line-height: 1.3;
}
.rail-mission-card .rmc-sub {
  font-size: 10.5px;
  color: var(--text-3);
  margin-bottom: 8px;
}
.rail-mission-card .rmc-bar {
  height: 3px;
  background: rgba(255,255,255,.06);
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 4px;
}
.rail-mission-card .rmc-fill {
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(90deg, #2f8fff, #00d4e8);
  box-shadow: 0 0 8px rgba(47,143,255,.5);
  transition: width .8s cubic-bezier(.4,0,.2,1);
}
.rail-mission-card .rmc-pct {
  font-family: var(--mono);
  font-size: 10px;
  color: #4fa2ff;
}

.rail-act-item {
  display: flex;
  gap: 9px;
  align-items: flex-start;
  padding: 8px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.rail-act-item:last-child { border-bottom: 0; }
.rail-act-item .rai-dot {
  width: 6px; height: 6px; border-radius: 50%;
  flex: 0 0 6px; margin-top: 5px;
  background: var(--blue);
  box-shadow: 0 0 6px rgba(47,143,255,.5);
}
.rail-act-item .rai-dot.green { background: var(--green); box-shadow: 0 0 6px rgba(0,229,160,.5); }
.rail-act-item .rai-dot.amber { background: var(--amber); box-shadow: 0 0 6px rgba(255,176,32,.5); }
.rail-act-item .rai-dot.violet { background: var(--violet); box-shadow: 0 0 6px rgba(168,85,247,.5); }
.rail-act-item .rai-text { font-size: 11.5px; color: var(--text-2); line-height: 1.4; }
.rail-act-item .rai-time { font-size: 9.5px; font-family: var(--mono); color: var(--text-4); margin-left: auto; flex: 0 0 auto; white-space: nowrap; }

/* ── MARKT TICKER PREMIUM ── */
.market-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 6px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
  font-size: 12px;
}
.market-row:last-child { border-bottom: 0; }
.market-row .mr-name { font-weight: 600; color: var(--text); }
.market-row .mr-val  { font-family: var(--mono); color: var(--text); }
.market-row .mr-chg  { font-family: var(--mono); font-size: 10.5px; padding: 2px 6px; border-radius: 4px; font-weight: 600; }
.market-row .mr-chg.up   { color: var(--green); background: rgba(0,229,160,.1); }
.market-row .mr-chg.down { color: var(--red);   background: rgba(255,77,106,.1); }

/* ── BOTTOM COMMAND BAR (JARVIS-style) ── */
#dash-command-bar {
  background: linear-gradient(160deg, rgba(255,255,255,.04), rgba(255,255,255,.018));
  border: 1px solid rgba(47,143,255,.22);
  border-radius: 14px;
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 18px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.055),
    0 0 0 1px rgba(47,143,255,.06),
    0 8px 32px rgba(0,0,0,.25);
  backdrop-filter: blur(16px);
}
#dash-command-bar input {
  flex: 1;
  background: transparent;
  border: 0;
  outline: 0;
  color: var(--text);
  font: 400 15px/1 var(--font);
  placeholder-color: var(--text-3);
}
#dash-command-bar input::placeholder { color: var(--text-3); }
.cmd-quick-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border-radius: 7px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.04);
  color: var(--text-3);
  font-size: 11.5px;
  cursor: pointer;
  transition: all .14s;
  white-space: nowrap;
}
.cmd-quick-btn:hover {
  background: rgba(47,143,255,.1);
  border-color: rgba(47,143,255,.25);
  color: #60b0ff;
}
.cmd-send-btn {
  width: 38px; height: 38px;
  border-radius: 10px;
  background: linear-gradient(135deg, #2f8fff, #1a72e0);
  border: 0;
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(47,143,255,.35);
  transition: all .14s;
  flex: 0 0 38px;
}
.cmd-send-btn:hover { filter: brightness(1.12); transform: scale(1.04); }

/* ── BRAIN VIEW PREMIUM ── */
.brain-stat-card {
  background: linear-gradient(160deg, rgba(255,255,255,.038), rgba(255,255,255,.012));
  border: 1px solid rgba(255,255,255,.065);
  border-radius: 10px;
  padding: 14px;
  transition: border-color .15s;
}
.brain-stat-card:hover { border-color: rgba(47,143,255,.22); }
.brain-stat-card .bsc-label {
  font-size: 9px; font-weight: 700; letter-spacing: .12em;
  text-transform: uppercase; color: var(--text-3); margin-bottom: 8px;
}
.brain-stat-card .bsc-val {
  font-size: 26px; font-weight: 750; font-family: var(--mono);
  color: var(--blue); line-height: 1;
  text-shadow: 0 0 20px rgba(47,143,255,.35);
}
.brain-stat-card .bsc-val.green  { color: var(--green);  text-shadow: 0 0 20px rgba(0,229,160,.35); }
.brain-stat-card .bsc-val.amber  { color: var(--amber);  text-shadow: 0 0 20px rgba(255,176,32,.35); }
.brain-stat-card .bsc-val.cyan   { color: var(--cyan);   text-shadow: 0 0 20px rgba(0,212,232,.35); }
.brain-stat-card .bsc-sub { font-size: 10.5px; color: var(--text-3); margin-top: 4px; }
.brain-stat-card .bsc-trend { font-size: 10.5px; margin-top: 4px; }
.brain-stat-card .bsc-trend.up   { color: var(--green); }
.brain-stat-card .bsc-trend.down { color: var(--red); }

/* Brain Status Badge */
.brain-status-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 99px;
  font-size: 10.5px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase;
}
.brain-status-badge.optimal {
  background: rgba(0,229,160,.12);
  border: 1px solid rgba(0,229,160,.3);
  color: var(--green);
}
.brain-status-badge.learning {
  background: rgba(47,143,255,.12);
  border: 1px solid rgba(47,143,255,.3);
  color: var(--blue);
}
.brain-status-badge .bsb-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
  animation: bsbPulse 2s infinite;
}
@keyframes bsbPulse { 0%,100%{opacity:1;} 50%{opacity:.3;} }

/* Wissensbereich Progress Bar */
.wissen-bar {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 7px; font-size: 11.5px;
}
.wissen-bar .wb-name { flex: 0 0 140px; color: var(--text-2); }
.wissen-bar .wb-track {
  flex: 1; height: 4px;
  background: rgba(255,255,255,.06); border-radius: 99px; overflow: hidden;
}
.wissen-bar .wb-fill {
  height: 100%; border-radius: 99px;
  background: linear-gradient(90deg, #2f8fff, #00d4e8);
  transition: width .8s cubic-bezier(.4,0,.2,1);
}
.wissen-bar .wb-pct { font-family: var(--mono); font-size: 10.5px; color: var(--text-3); width: 34px; text-align: right; }

/* ── HEADER PREMIUM ── */
#header {
  background: rgba(3,5,10,.88) !important;
  border-bottom: 1px solid rgba(255,255,255,.045) !important;
  backdrop-filter: blur(24px) !important;
}

/* ── CARD-HEAD PREMIUM ── */
.card-head {
  font-size: 9.5px !important;
  font-weight: 700 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: var(--text-3) !important;
}

/* ── PILLS & BADGES ── */
.pill {
  background: rgba(255,255,255,.05) !important;
  border-color: rgba(255,255,255,.08) !important;
  color: var(--text-2) !important;
  font-size: 11px !important;
}
.pill.live-dot::before {
  content: '';
  display: inline-block;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--green);
  box-shadow: 0 0 6px var(--green);
  margin-right: 5px;
  animation: bsbPulse 2s infinite;
}

/* ── SCROLLBAR ── */
::-webkit-scrollbar { width: 3px; height: 3px; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,.07); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.14); }

/* ── ANIMATIONS ── */
@keyframes shimmer {
  0%   { background-position: -200% center; }
  100% { background-position:  200% center; }
}
.shimmer-text {
  background: linear-gradient(90deg,
    var(--text-2) 0%, var(--text) 40%, #4fa2ff 50%, var(--text) 60%, var(--text-2) 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer 3s linear infinite;
}

@keyframes glowPulse {
  0%,100% { box-shadow: 0 0 0 0 rgba(47,143,255,0); }
  50%     { box-shadow: 0 0 20px 4px rgba(47,143,255,.18); }
}
.glow-pulse { animation: glowPulse 3s ease-in-out infinite; }

/* ── MISSION CARDS UPGRADE ── */
.mission-card {
  background: linear-gradient(160deg, rgba(255,255,255,.038), rgba(255,255,255,.014)) !important;
  border-color: rgba(255,255,255,.07) !important;
}
.mission-card:hover { border-color: rgba(47,143,255,.25) !important; }

/* ── REVENUE PAGE PREMIUM ── */
.rev-big-num {
  font-size: clamp(38px,3vw,56px);
  font-weight: 750;
  font-family: var(--mono);
  line-height: 1;
  background: linear-gradient(135deg, #00e5a0 0%, #2f8fff 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ── TASK ITEMS ── */
.task-row { color: var(--text-2) !important; }
.task-row:hover { color: var(--text) !important; }

/* ── STATUS BAR ── */
#zeus-status-bar {
  background: rgba(3,5,10,.95) !important;
  border-top-color: rgba(255,255,255,.045) !important;
}

/* ── CHAT BUBBLES JARVIS-STYLE ── */
.msg.user .msg-bubble, .msg.user .bubble {
  background: rgba(47,143,255,.08) !important;
  border-color: rgba(47,143,255,.18) !important;
}

/* Chat Action Cards (Jarvis-style structured response boxes) */
.chat-action-card {
  background: rgba(255,255,255,.038);
  border: 1px solid rgba(255,255,255,.08);
  border-left: 3px solid var(--blue);
  border-radius: 9px;
  padding: 12px 14px;
  margin-top: 8px;
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.5;
}
.chat-action-card .cac-title {
  font-size: 11.5px; font-weight: 700; color: var(--blue);
  text-transform: uppercase; letter-spacing: .08em; margin-bottom: 6px;
}

/* Thinking Indicator */
.thinking-dots span {
  display: inline-block;
  width: 5px; height: 5px; border-radius: 50%;
  background: var(--blue);
  margin: 0 2px;
  animation: thinkDot 1.4s ease-in-out infinite;
}
.thinking-dots span:nth-child(2) { animation-delay: .2s; }
.thinking-dots span:nth-child(3) { animation-delay: .4s; }
@keyframes thinkDot {
  0%,80%,100% { transform: scale(.6); opacity: .3; }
  40%          { transform: scale(1);  opacity: 1;  }
}

/* ── VIEW TRANSITION ── */
.view-panel.active {
  animation: jarvisIn .28s cubic-bezier(.22,.68,0,1.15) both !important;
}
@keyframes jarvisIn {
  from { opacity: 0; transform: translateY(10px) scale(.99); }
  to   { opacity: 1; transform: none; }
}

/* ═══════════════════════════════════════════════
   JARVIS BRAIN VIEW UPGRADE
═══════════════════════════════════════════════ */

/* Brain metric cards — glass panels */
.brain-metric {
  background: linear-gradient(160deg, rgba(255,255,255,.042), rgba(255,255,255,.015)) !important;
  border: 1px solid rgba(79,142,255,.12) !important;
  border-radius: 12px !important;
  padding: 16px !important;
  position: relative;
  overflow: hidden;
}
.brain-metric::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(79,142,255,.3), transparent);
}
.brain-metric .label {
  font-size: 9px !important;
  font-weight: 700 !important;
  letter-spacing: .14em !important;
  text-transform: uppercase !important;
  color: rgba(120,160,220,.45) !important;
  margin-bottom: 8px !important;
}
.brain-metric .bm-big {
  font-size: 36px !important;
  font-weight: 750 !important;
  font-family: var(--mono) !important;
  background: linear-gradient(135deg, #fff 0%, #4f8eff 100%);
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  line-height: 1.1;
  text-shadow: none !important;
}
.brain-metric .bm-big span {
  font-size: 18px !important;
  opacity: .6;
}
.brain-metric .muted {
  font-size: 10px !important;
  color: rgba(120,150,190,.4) !important;
  margin-top: 4px;
}
.brain-metric .mem-row {
  display: flex;
  justify-content: space-between;
  font-size: 11.5px;
  color: var(--text-3);
  padding: 3px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
.brain-metric .mem-row .mono {
  color: var(--blue);
  font-weight: 600;
}

/* Brain canvas container */
.brain-center {
  position: relative;
}
#brain-canvas {
  border-radius: 50%;
  box-shadow: 0 0 60px rgba(79,142,255,.15), 0 0 120px rgba(79,142,255,.06);
}
.brain-status {
  background: linear-gradient(160deg, rgba(255,255,255,.038), rgba(255,255,255,.015)) !important;
  border: 1px solid rgba(79,142,255,.12) !important;
  border-radius: 10px !important;
  padding: 10px 14px !important;
}

/* Knowledge bars — JARVIS style */
#br-top-knowledge .know-item,
#knowledge-base .know-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 0;
  border-bottom: 1px solid rgba(255,255,255,.04);
}
#br-top-knowledge .know-label,
#knowledge-base .know-label {
  width: 130px;
  font-size: 11.5px;
  color: var(--text-3);
  flex-shrink: 0;
}
#br-top-knowledge .know-bar-wrap,
#knowledge-base .know-bar-wrap {
  flex: 1;
  height: 4px;
  background: rgba(255,255,255,.06);
  border-radius: 99px;
  overflow: hidden;
}
#br-top-knowledge .know-bar,
#knowledge-base .know-bar {
  height: 100%;
  border-radius: 99px;
  background: linear-gradient(90deg, #2f8fff, #00d4e8);
  box-shadow: 0 0 8px rgba(47,143,255,.5);
  transition: width 1.2s cubic-bezier(.4,0,.2,1);
}
#br-top-knowledge .know-pct,
#knowledge-base .know-pct {
  width: 36px;
  text-align: right;
  font-size: 11px;
  font-family: var(--mono);
  color: var(--blue);
  font-weight: 600;
}

/* Brain-stat-cards (matching dashboard KPI style) */
.brain-stat-card {
  background: linear-gradient(160deg, rgba(255,255,255,.04), rgba(255,255,255,.015));
  border: 1px solid rgba(255,255,255,.07);
  border-radius: 11px;
  padding: 16px;
}
.bsc-label {
  font-size: 9px; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: rgba(120,160,220,.4); margin-bottom: 6px;
}
.bsc-val {
  font-size: 28px; font-weight: 750; font-family: var(--mono);
  background: linear-gradient(135deg, #fff 0%, #4f8eff 100%);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}


/* ═══════════════════════════════════════════════
   JARVIS REVENUE VIEW UPGRADE
═══════════════════════════════════════════════ */

#view-revenue .rev-big-num,
.rev-big-num {
  font-size: 52px !important;
  font-weight: 800 !important;
  font-family: var(--mono) !important;
  background: linear-gradient(135deg, #fff 0%, #00e5a0 60%, #2f8fff 100%);
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  letter-spacing: -.02em;
  line-height: 1;
}
.rev-kpi-card {
  background: linear-gradient(160deg, rgba(255,255,255,.042), rgba(255,255,255,.015));
  border: 1px solid rgba(0,229,160,.1);
  border-radius: 12px;
  padding: 18px;
  text-align: center;
}
.rev-kpi-label {
  font-size: 9px; font-weight: 700; letter-spacing: .14em;
  text-transform: uppercase; color: rgba(0,229,160,.4); margin-bottom: 8px;
}
.rev-kpi-val {
  font-size: 28px; font-weight: 750; font-family: var(--mono);
  background: linear-gradient(135deg, #00e5a0, #2f8fff);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent;
  background-clip: text;
}
.rev-trend-up   { color: #00e5a0 !important; }
.rev-trend-down { color: #f16868 !important; }

/* Revenue chart bars */
.rev-bar-item {
  display: flex; align-items: center; gap: 10px; padding: 5px 0;
}
.rev-bar-label { width: 80px; font-size: 11px; color: var(--text-3); flex-shrink: 0; }
.rev-bar-wrap  { flex:1; height:5px; background:rgba(255,255,255,.06); border-radius:99px; overflow:hidden; }
.rev-bar-fill  { height:100%; border-radius:99px; background:linear-gradient(90deg,#00e5a0,#2f8fff); box-shadow:0 0 8px rgba(0,229,160,.4); transition:width 1.2s cubic-bezier(.4,0,.2,1); }
.rev-bar-val   { width:60px; text-align:right; font-size:11px; font-family:var(--mono); color:var(--green); font-weight:600; }


/* ═══════════════════════════════════════════════
   JARVIS MISSIONS VIEW UPGRADE
═══════════════════════════════════════════════ */

.mission-card-j {
  background: linear-gradient(160deg, rgba(255,255,255,.042), rgba(255,255,255,.015));
  border: 1px solid rgba(47,143,255,.1);
  border-radius: 13px;
  padding: 18px 20px;
  margin-bottom: 12px;
  position: relative;
  overflow: hidden;
  transition: border-color .2s, box-shadow .2s;
}
.mission-card-j:hover {
  border-color: rgba(47,143,255,.25);
  box-shadow: 0 0 20px rgba(47,143,255,.08);
}
.mission-card-j::before {
  content: '';
  position: absolute;
  top: 0; left: 0;
  width: 3px; height: 100%;
  background: linear-gradient(180deg, #2f8fff, #00d4e8);
  border-radius: 3px 0 0 3px;
}
.mcj-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.mcj-title  { font-size:14px; font-weight:650; color:var(--text); }
.mcj-status {
  font-size:9px; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:3px 8px; border-radius:99px;
}
.mcj-status.running { background:rgba(47,143,255,.12); color:#4f8eff; border:1px solid rgba(47,143,255,.25); }
.mcj-status.done    { background:rgba(0,229,160,.1);   color:#00e5a0; border:1px solid rgba(0,229,160,.2); }
.mcj-status.paused  { background:rgba(245,166,35,.1);  color:#f5a623; border:1px solid rgba(245,166,35,.2); }
.mcj-desc { font-size:12px; color:var(--text-3); margin-bottom:12px; line-height:1.5; }
.mcj-progress-wrap { display:flex; align-items:center; gap:10px; }
.mcj-bar-outer { flex:1; height:4px; background:rgba(255,255,255,.06); border-radius:99px; overflow:hidden; }
.mcj-bar-inner { height:100%; border-radius:99px; background:linear-gradient(90deg,#2f8fff,#00d4e8); box-shadow:0 0 8px rgba(47,143,255,.5); transition:width 1s; }
.mcj-pct { font-size:11px; font-family:var(--mono); color:var(--blue); font-weight:700; width:36px; text-align:right; }

/* Blink animation for running status */
@keyframes bsbPulse {
  0%,100%{opacity:1;} 50%{opacity:.4;}
}

