*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

:root {
  --bg: #050508;
  --surface: #0a0a10;
  --surface-2: #111118;
  --surface-3: #1a1a24;
  --border: rgba(100,200,255,0.08);
  --text: #e0f0ff;
  --text-dim: #708090;
  --accent: #00d4ff;
  --accent-dim: rgba(0,212,255,0.3);
  --error: #ff3366;
  --error-dim: rgba(255,51,102,0.2);
  --warn: #ffaa00;
  --warn-dim: rgba(255,170,0,0.2);
  --success: #00ff88;
  --success-dim: rgba(0,255,136,0.2);
  --info: #4488ff;
  --info-dim: rgba(68,136,255,0.2);
  --debug: #aa66ff;
  --debug-dim: rgba(170,102,255,0.2);
  --mono: 'JetBrains Mono', monospace;
  --sans: 'Inter', sans-serif;
}

html, body {
  height: 100%;
  background: var(--bg);
  color: var(--text);
  font-family: var(--sans);
  overflow: hidden;
}

.app {
  display: flex;
  flex-direction: column;
  height: 100vh;
  position: relative;
}

/* ===== ANIMATED BACKGROUND ===== */
.bg-noise {
  position: fixed;
  inset: 0;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 0;
}

.bg-orb {
  position: fixed;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  z-index: 0;
}
.bg-orb-1 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(0,212,255,0.15), transparent 70%);
  top: -100px; right: -100px;
  animation: orbFloat1 20s ease-in-out infinite;
}
.bg-orb-2 {
  width: 300px; height: 300px;
  background: radial-gradient(circle, rgba(255,51,102,0.1), transparent 70%);
  bottom: -50px; left: -50px;
  animation: orbFloat2 25s ease-in-out infinite;
}
.bg-orb-3 {
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(170,102,255,0.12), transparent 70%);
  top: 50%; left: 50%;
  animation: orbFloat3 18s ease-in-out infinite;
}
@keyframes orbFloat1 {
  0%,100%{transform:translate(0,0)scale(1)}
  33%{transform:translate(-30px,20px)scale(1.1)}
  66%{transform:translate(20px,-20px)scale(0.9)}
}
@keyframes orbFloat2 {
  0%,100%{transform:translate(0,0)}
  50%{transform:translate(40px,-30px)}
}
@keyframes orbFloat3 {
  0%,100%{transform:translate(-50%,-50%)}
  50%{transform:translate(-40%,-60%)scale(1.2)}
}

/* Scanline effect */
.scanlines {
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,0,0,0.15) 2px,
    rgba(0,0,0,0.15) 4px
  );
  pointer-events: none;
  z-index: 9999;
  opacity: 0.3;
}

/* ===== HEADER ===== */
.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 24px;
  background: rgba(10,10,16,0.9);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  position: relative;
  z-index: 10;
}
.header::after {
  content:'';
  position:absolute;
  bottom:0;left:0;right:0;
  height:1px;
  background: linear-gradient(90deg,transparent,var(--accent),transparent);
  opacity:0.5;
}

.header-left, .header-right { display:flex;align-items:center;gap:16px; }

.logo { display:flex;align-items:center;gap:12px; }
.logo-icon-wrap {
  width:36px;height:36px;
  border-radius:10px;
  background: linear-gradient(135deg,rgba(0,212,255,0.2),rgba(170,102,255,0.2));
  border:1px solid rgba(0,212,255,0.3);
  display:flex;align-items:center;justify-content:center;
  box-shadow: 0 0 20px rgba(0,212,255,0.2);
  animation: iconPulse 3s ease-in-out infinite;
}
@keyframes iconPulse {
  0%,100%{box-shadow:0 0 20px rgba(0,212,255,0.2)}
  50%{box-shadow:0 0 30px rgba(0,212,255,0.4)}
}
.logo-icon { width:20px;height:20px;color:var(--accent); }
.logo-text-wrap { display:flex;gap:2px; }
.logo-text { font-size:20px;font-weight:800;letter-spacing:-0.5px; }
.logo-text.accent {
  background: linear-gradient(135deg,#00d4ff,#aa66ff);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

.status-pill {
  display:flex;align-items:center;gap:8px;
  padding:6px 14px;
  border-radius:20px;
  background: rgba(255,255,255,0.03);
  border:1px solid var(--border);
  font-size:12px;
  font-weight:600;
  color:var(--text-dim);
}
.status-ring {
  width:8px;height:8px;border-radius:50%;
  background:var(--warn);
  box-shadow:0 0 10px var(--warn);
  animation: statusBlink 2s infinite;
}
@keyframes statusBlink {
  0%,100%{opacity:1}
  50%{opacity:0.3}
}
.status-pill.connected .status-ring {
  background:var(--success);
  box-shadow:0 0 10px var(--success);
  animation: statusBlink 2s infinite;
}
.status-pill.connected .status-label { color:var(--success); }
.status-pill.error .status-ring {
  background:var(--error);
  box-shadow:0 0 10px var(--error);
}

.icon-btn {
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  color:var(--text-dim);
  width:36px;height:36px;
  border-radius:10px;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all 0.3s;
}
.icon-btn:hover {
  background:rgba(0,212,255,0.1);
  border-color:rgba(0,212,255,0.3);
  color:var(--accent);
  transform:translateY(-2px);
  box-shadow:0 4px 15px rgba(0,212,255,0.1);
}
.icon-btn svg { width:18px;height:18px; }

/* ===== MAIN PANEL ===== */
.main-panel {
  flex:1;
  display:flex;
  flex-direction:column;
  position:relative;
  z-index:5;
  overflow:hidden;
}

/* ===== CONTROLS ===== */
.controls {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:12px 24px;
  gap:16px;
  border-bottom:1px solid var(--border);
  background:rgba(10,10,16,0.7);
  backdrop-filter:blur(8px);
}
.controls-left, .controls-right { display:flex;align-items:center;gap:12px; }

.select-wrap { position:relative; }
.app-select {
  appearance:none;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  color:var(--text);
  padding:10px 36px 10px 14px;
  border-radius:12px;
  font-size:14px;font-weight:500;
  font-family:var(--sans);
  cursor:pointer;
  min-width:200px;
  transition:all 0.3s;
  outline:none;
}
.app-select:hover {
  border-color:rgba(0,212,255,0.3);
  background:rgba(0,212,255,0.05);
}
.app-select:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(0,212,255,0.1),0 0 20px rgba(0,212,255,0.1);
}
.chevron {
  position:absolute;right:12px;top:50%;
  transform:translateY(-50%);
  width:16px;height:16px;
  color:var(--text-dim);
  pointer-events:none;
}

.watch-btn {
  display:flex;align-items:center;gap:8px;
  padding:10px 20px;
  border-radius:12px;
  font-size:14px;font-weight:600;
  font-family:var(--sans);
  cursor:pointer;
  border:none;
  background: linear-gradient(135deg,#00d4ff,#667eea);
  color:#000;
  box-shadow:0 4px 20px rgba(0,212,255,0.3);
  transition:all 0.3s;
}
.watch-btn:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(0,212,255,0.4);
}
.watch-btn:active { transform:translateY(0); }
.watch-btn:disabled {
  opacity:0.4;cursor:not-allowed;
  transform:none;box-shadow:none;
}
.watch-btn svg { width:16px;height:16px; }

.ctrl-btn {
  display:flex;align-items:center;gap:6px;
  padding:10px 16px;
  border-radius:12px;
  font-size:14px;font-weight:600;
  font-family:var(--sans);
  cursor:pointer;
  border:1px solid var(--border);
  background:rgba(255,255,255,0.03);
  color:var(--text-dim);
  transition:all 0.3s;
}
.ctrl-btn:hover {
  background:rgba(255,255,255,0.06);
  color:var(--text);
  border-color:rgba(255,255,255,0.15);
}
.ctrl-btn:disabled { opacity:0.4;cursor:not-allowed; }
.ctrl-btn svg { width:16px;height:16px; }

.search-wrap { position:relative; }
.search-icon {
  position:absolute;left:12px;top:50%;
  transform:translateY(-50%);
  width:16px;height:16px;
  color:var(--text-dim);
}
.search {
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  color:var(--text);
  padding:10px 14px 10px 38px;
  border-radius:12px;
  font-size:14px;
  font-family:var(--sans);
  width:200px;
  transition:all 0.3s;
  outline:none;
}
.search:hover, .search:focus {
  border-color:rgba(0,212,255,0.3);
  width:260px;
  box-shadow:0 0 0 3px rgba(0,212,255,0.05);
}
.search::placeholder { color:var(--text-dim); }

.stats { display:flex;gap:8px; }
.stat-chip {
  padding:6px 12px;
  border-radius:8px;
  font-size:12px;
  font-weight:600;
  color:var(--text-dim);
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  transition:all 0.3s;
}
.stat-chip.errors {
  color:var(--error);
  background:var(--error-dim);
  border-color:rgba(255,51,102,0.3);
}

/* ===== LEVEL FILTERS ===== */
.level-filters {
  display:flex;
  gap:8px;
  padding:10px 24px;
  border-bottom:1px solid var(--border);
  background:rgba(10,10,16,0.5);
  overflow-x:auto;
}
.level-btn {
  display:flex;align-items:center;gap:6px;
  padding:6px 14px;
  border-radius:20px;
  font-size:12px;
  font-weight:600;
  cursor:pointer;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border);
  color:var(--text-dim);
  transition:all 0.3s;
  user-select:none;
  white-space:nowrap;
}
.level-btn:hover {
  border-color:rgba(0,212,255,0.3);
  color:var(--text);
  transform:translateY(-2px);
}
.level-btn.active {
  color:var(--text);
  border-color:rgba(255,255,255,0.15);
  background:rgba(255,255,255,0.05);
}
.level-btn .dot {
  width:8px;height:8px;border-radius:50%;
  transition:transform 0.3s,box-shadow 0.3s;
}
.level-btn:hover .dot { transform:scale(1.3); }
.level-btn.active .dot { box-shadow:0 0 8px currentColor; }

/* ===== LOG VIEWPORT ===== */
.log-viewport {
  flex:1;
  overflow-y:auto;
  position:relative;
  font-family:var(--mono);
  font-size:13px;
  line-height:1.7;
}
.log-viewport::-webkit-scrollbar { width:6px; }
.log-viewport::-webkit-scrollbar-track { background:transparent; }
.log-viewport::-webkit-scrollbar-thumb {
  background:rgba(255,255,255,0.08);
  border-radius:3px;
}
.log-viewport::-webkit-scrollbar-thumb:hover { background:rgba(255,255,255,0.15); }

/* ===== EMPTY STATE ===== */
.empty-state {
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  height:100%;
  text-align:center;
}
.terminal-window {
  background: var(--surface-2);
  border-radius: 12px;
  border: 1px solid var(--border);
  overflow: hidden;
  width: 400px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5), 0 0 40px rgba(0,212,255,0.05);
  animation: termFloat 6s ease-in-out infinite;
}
@keyframes termFloat {
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-10px)}
}
.terminal-bar {
  display:flex;align-items:center;gap:8px;
  padding:10px 16px;
  background:rgba(255,255,255,0.03);
  border-bottom:1px solid var(--border);
}
.term-dot { width:12px;height:12px;border-radius:50%; }
.term-dot.red { background:var(--error);box-shadow:0 0 8px var(--error); }
.term-dot.yellow { background:var(--warn);box-shadow:0 0 8px var(--warn); }
.term-dot.green { background:var(--success);box-shadow:0 0 8px var(--success); }
.term-title { font-size:11px;color:var(--text-dim);margin-left:8px; }
.terminal-body { padding:20px;text-align:left; }
.term-line { margin:6px 0;font-size:13px; }
.term-prompt { color:var(--accent);margin-right:8px; }
.term-cursor {
  color:var(--accent);
  animation: cursorBlink 1s infinite;
}
@keyframes cursorBlink {
  0%,100%{opacity:1}
  50%{opacity:0}
}
.empty-hint {
  margin-top:24px;
  color:var(--text-dim);
  font-size:14px;
}
.empty-hint kbd {
  background:rgba(255,255,255,0.08);
  border:1px solid var(--border);
  padding:2px 8px;
  border-radius:6px;
  font-family:var(--mono);
  font-size:12px;
  color:var(--accent);
}

/* ===== LOG LINES ===== */
.log-stream { padding:8px 0; }
.log-line {
  display:flex;align-items:flex-start;gap:12px;
  padding:5px 24px;
  border-left:3px solid transparent;
  transition:all 0.15s;
  animation: logIn 0.3s ease-out;
  position:relative;
}
@keyframes logIn {
  from { opacity:0;transform:translateX(-8px); }
  to { opacity:1;transform:translateX(0); }
}
.log-line::before {
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(90deg,rgba(0,212,255,0.02),transparent);
  opacity:0;
  transition:opacity 0.2s;
}
.log-line:hover::before { opacity:1; }
.log-line:hover { background:rgba(255,255,255,0.02); }
.log-line.hidden { display:none; }

.log-line.error {
  border-left-color:var(--error);
  background:var(--error-dim);
}
.log-line.warn {
  border-left-color:var(--warn);
  background:var(--warn-dim);
}
.log-line.success {
  border-left-color:var(--success);
  background:var(--success-dim);
}
.log-line.info { border-left-color:var(--info); }
.log-line.debug { border-left-color:var(--debug);opacity:0.5; }

.log-ts {
  color:var(--text-dim);
  font-size:11px;
  white-space:nowrap;
  min-width:80px;
  flex-shrink:0;
  font-weight:500;
}
.log-badge {
  font-size:9px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.5px;
  padding:2px 8px;
  border-radius:6px;
  min-width:48px;
  text-align:center;
  flex-shrink:0;
}
.log-badge.error { background:rgba(255,51,102,0.15);color:#ff6688; }
.log-badge.warn { background:rgba(255,170,0,0.15);color:#ffcc44; }
.log-badge.info { background:rgba(68,136,255,0.15);color:#66aaff; }
.log-badge.success { background:rgba(0,255,136,0.15);color:#44ffaa; }
.log-badge.debug { background:rgba(170,102,255,0.15);color:#bb88ff; }

.log-msg {
  color:var(--text);
  word-break:break-all;
  flex:1;
}
.log-msg .hl { color:var(--accent);font-weight:600; }

/* Streaming indicator bar */
.stream-active::after {
  content:'';
  position:fixed;
  top:0;left:0;right:0;
  height:2px;
  background: linear-gradient(90deg,transparent,var(--accent),transparent);
  animation: streamPulse 2s infinite;
  z-index:100;
}
@keyframes streamPulse {
  0%,100%{opacity:0.3}
  50%{opacity:1}
}

/* ===== FAB ===== */
.fab {
  position:fixed;
  bottom:24px;right:24px;
  width:48px;height:48px;
  border-radius:50%;
  background: linear-gradient(135deg,var(--accent),#667eea);
  border:none;
  color:#000;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 20px rgba(0,212,255,0.4);
  transition:all 0.3s;
  opacity:0;
  transform:translateY(20px);
  pointer-events:none;
  z-index:100;
}
.fab.visible {
  opacity:1;
  transform:translateY(0);
  pointer-events:all;
}
.fab:hover {
  transform:translateY(-3px)scale(1.1);
  box-shadow:0 8px 30px rgba(0,212,255,0.5);
}
.fab:active { transform:scale(0.95); }
.fab svg { width:20px;height:20px; }

/* ===== RESPONSIVE ===== */
@media (max-width:768px) {
  .controls { flex-direction:column;align-items:stretch; }
  .controls-left,.controls-right { justify-content:center;flex-wrap:wrap; }
  .search,.search:hover,.search:focus { width:100%; }
  .app-select { min-width:100%; }
  .level-filters { padding:8px 16px; }
  .log-line { flex-direction:column;gap:4px;padding:6px 16px; }
  .log-ts { min-width:auto; }
  .terminal-window { width:90%;max-width:400px; }
}
