/* events.css — Market Events page, login banner and T-minus toasts.
   Themed via the app's CSS variables (styles.css) so it adapts to
   dark / navy / light automatically. See web/events.js. */

/* ── Page ──────────────────────────────────────────────────────────────── */
[data-page="events"] .ev-wrap { max-width: 920px; margin: 0 auto; padding: 6px 14px 40px; }

.ev-intro { color: var(--muted); font-size: 13px; margin: 2px 0 12px; line-height: 1.5; }

#ev-filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
#ev-filters .ev-fbtn {
  appearance: none; cursor: pointer; border: 1px solid var(--border);
  background: var(--panel); color: var(--text-2);
  border-radius: 999px; padding: 5px 13px; font-size: 12.5px; font-weight: 600;
  transition: background .12s, color .12s, border-color .12s;
}
#ev-filters .ev-fbtn:hover { color: var(--text); border-color: var(--accent); }
#ev-filters .ev-fbtn.active { background: var(--accent); border-color: var(--accent); color: #fff; }

.ev-loading, .ev-empty { color: var(--muted); padding: 40px 6px; text-align: center; font-size: 14px; }

.ev-day { margin-bottom: 18px; }
.ev-day-head {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
  color: var(--muted); padding: 0 2px 7px; border-bottom: 1px solid var(--border); margin-bottom: 10px;
}
.ev-day-today .ev-day-head { color: var(--accent); }
.ev-today-tag {
  font-size: 10px; font-weight: 800; letter-spacing: .06em; color: #fff;
  background: var(--oa-red, #e0556a); border-radius: 4px; padding: 1px 6px;
}

/* Event card — severity strip on the left edge. */
.ev-card {
  display: flex; gap: 14px; background: var(--panel); border: 1px solid var(--border);
  border-left: 3px solid var(--border); border-radius: 10px; padding: 11px 14px; margin-bottom: 9px;
}
.ev-card.ev-sev-high { border-left-color: var(--oa-red, #e0556a); }
.ev-card.ev-sev-med  { border-left-color: var(--oa-orange, #e0913f); }
.ev-card.ev-sev-low  { border-left-color: var(--oa-gray, #8590a0); }

.ev-time {
  flex: 0 0 64px; font-variant-numeric: tabular-nums; font-weight: 700; font-size: 14px;
  color: var(--text); display: flex; flex-direction: column; gap: 3px;
}
.ev-exch { font-size: 10px; font-weight: 600; color: var(--muted); letter-spacing: .03em; }

.ev-main { flex: 1 1 auto; min-width: 0; }
.ev-row1 { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.ev-sev-dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; background: var(--oa-gray, #8590a0); }
.ev-sev-high .ev-sev-dot { background: var(--oa-red, #e0556a); box-shadow: 0 0 0 3px rgba(224,85,106,.18); }
.ev-sev-med  .ev-sev-dot { background: var(--oa-orange, #e0913f); }
.ev-title { font-weight: 650; font-size: 14px; color: var(--text); }

.ev-chip {
  font-size: 10.5px; font-weight: 700; letter-spacing: .03em; border-radius: 5px; padding: 1px 7px;
  text-transform: uppercase;
}
.ev-cat-macro { color: var(--oa-blue, #4a90e2);   background: var(--oa-blue-bg, rgba(74,144,226,.12)); }
.ev-cat-index { color: var(--oa-purple, #9b6bd6); background: var(--oa-purple-bg, rgba(155,107,214,.12)); }
.ev-cat-stock { color: var(--oa-green, #3fa85f);  background: var(--oa-green-bg, rgba(63,168,95,.12)); }
.ev-cat-corp  { color: var(--oa-orange, #e0913f); background: var(--oa-orange-bg, rgba(224,145,63,.12)); }

.ev-desc { color: var(--text-2); font-size: 12.5px; line-height: 1.5; margin: 5px 0 6px; }
.ev-syms { display: flex; flex-wrap: wrap; gap: 5px; }
.ev-sym {
  font-size: 11px; font-weight: 600; color: var(--text-2); background: var(--panel-2);
  border: 1px solid var(--border); border-radius: 4px; padding: 1px 6px;
}
.ev-sym-wide { color: var(--muted); font-style: italic; font-weight: 500; }

/* ── Login banner ──────────────────────────────────────────────────────── */
.ev-banner {
  position: fixed; top: 58px; left: 50%; transform: translateX(-50%);
  z-index: 8000; max-width: min(720px, 94vw);
  display: flex; align-items: center; gap: 10px;
  background: var(--panel); border: 1px solid var(--border); border-left: 4px solid var(--accent);
  border-radius: 10px; padding: 9px 12px; box-shadow: 0 8px 28px rgba(0,0,0,.28);
  animation: ev-drop .28s ease;
}
.ev-banner-high { border-left-color: var(--oa-red, #e0556a); }
@keyframes ev-drop { from { opacity: 0; transform: translate(-50%, -10px); } to { opacity: 1; transform: translate(-50%, 0); } }
.ev-banner-ico { font-size: 16px; }
.ev-banner-txt { font-size: 13px; color: var(--text-2); line-height: 1.4; min-width: 0; }
.ev-banner-txt b { color: var(--text); font-weight: 700; }
.ev-banner-view {
  appearance: none; cursor: pointer; white-space: nowrap; border: 1px solid var(--accent);
  background: var(--accent); color: #fff; border-radius: 7px; padding: 5px 11px; font-size: 12px; font-weight: 700;
}
.ev-banner-x {
  appearance: none; cursor: pointer; border: none; background: transparent; color: var(--muted);
  font-size: 18px; line-height: 1; padding: 0 2px;
}
.ev-banner-x:hover { color: var(--text); }

/* ── T-minus toasts ────────────────────────────────────────────────────── */
#ev-toast-stack {
  position: fixed; right: 18px; bottom: 18px; z-index: 9000;
  display: flex; flex-direction: column-reverse; gap: 10px; max-width: 360px;
}
.ev-toast {
  display: flex; gap: 11px; align-items: flex-start;
  background: var(--panel); border: 1px solid var(--border); border-left: 4px solid var(--oa-orange, #e0913f);
  border-radius: 10px; padding: 11px 12px; box-shadow: 0 10px 30px rgba(0,0,0,.32);
  opacity: 0; transform: translateX(20px); transition: opacity .26s, transform .26s;
}
.ev-toast.ev-sev-high { border-left-color: var(--oa-red, #e0556a); }
.ev-toast.ev-toast-in  { opacity: 1; transform: translateX(0); }
.ev-toast.ev-toast-out { opacity: 0; transform: translateX(20px); }
.ev-toast-ico { font-size: 17px; line-height: 1.2; }
.ev-toast-body { flex: 1 1 auto; min-width: 0; }
.ev-toast-title { font-weight: 700; font-size: 13px; color: var(--text); }
.ev-toast-sub { font-size: 12px; color: var(--text-2); line-height: 1.45; margin-top: 2px; }
.ev-toast-acts { display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }
.ev-toast-view {
  appearance: none; cursor: pointer; border: 1px solid var(--accent); background: var(--accent); color: #fff;
  border-radius: 6px; padding: 3px 9px; font-size: 11.5px; font-weight: 700; white-space: nowrap;
}
.ev-toast-x {
  appearance: none; cursor: pointer; border: none; background: transparent; color: var(--muted);
  font-size: 16px; line-height: 1; padding: 0 2px;
}
.ev-toast-x:hover { color: var(--text); }

@media (max-width: 560px) {
  .ev-banner { top: 52px; gap: 8px; padding: 8px 10px; }
  .ev-banner-txt { font-size: 12px; }
  #ev-toast-stack { right: 10px; left: 10px; bottom: 10px; max-width: none; }
}
