/* ==========================================================
   Nevoura — Analytics Page
   Dark theme · lime accent · matches Nevoura dashboard UI
   ========================================================== */

@import url("https://fonts.googleapis.com/css2?family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=DM+Mono:wght@400;500&display=swap");
@import url("https://cdn.jsdelivr.net/npm/bootstrap-icons@1.13.1/font/bootstrap-icons.min.css");

/* ── Analytics page: dark body scoped only to this page ─────── */
body.nv-analytics-active {
  background: #0d0f14 !important;
}

/* Kill any white borders/backgrounds from the WP theme wrapper */
body.nv-analytics-active .entry-content,
body.nv-analytics-active .post-content,
body.nv-analytics-active .page-content,
body.nv-analytics-active article,
body.nv-analytics-active .hentry,
body.nv-analytics-active .site-content,
body.nv-analytics-active main,
body.nv-analytics-active #main,
body.nv-analytics-active #content,
body.nv-analytics-active #primary {
  background: transparent !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 !important;
}

/* ── Root / tokens ─────────────────────────────────────────── */
.nv-analytics-page {
  --bg:        #0d0f14;
  --card:      #13161d;
  --card-2:    #191c24;
  --border:    rgba(255,255,255,.07);
  --border-md: rgba(255,255,255,.12);
  --ink:       #ffffff;
  --mid:       #c8cdd6;
  --muted:     #8b94a0;
  --dim:       #4a5260;
  --accent:    #c8f23a;
  --accent-2:  #d4f74e;
  --green:     #22c55e;
  --red:       #ef4444;
  --blue:      #38bdf8;
  --purple:    #a78bfa;
  --font:      "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;
  --mono:      "DM Mono", ui-monospace, monospace;
  --r:         14px;
  --r-sm:      9px;
  --r-xs:      6px;

  font-family: var(--font);
  color: var(--ink);
  background: var(--bg);
  max-width: 1100px;
  margin: 0 auto;
  padding: 36px 24px 72px;
}

/* ── Page header ───────────────────────────────────────────── */
.nv-an-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 32px;
  flex-wrap: wrap;
  gap: 14px;
}

.nv-an-supertitle {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0 0 6px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.nv-an-supertitle::before {
  content: '';
  display: inline-block;
  width: 20px;
  height: 1.5px;
  background: var(--accent);
  border-radius: 99px;
}

.nv-an-title {
  font-size: 32px;
  font-weight: 700;
  letter-spacing: -.6px;
  color: var(--ink);
  margin: 0 0 4px;
  line-height: 1.05;
}

.nv-an-subtitle {
  font-size: 13px;
  color: var(--muted);
  margin: 0;
}

.nv-an-header-right {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
  color: var(--muted);
  white-space: nowrap;
}

.nv-an-updated {
  font-family: var(--mono);
  font-size: 11px;
  color: var(--dim);
}

/* ── Live dot ──────────────────────────────────────────────── */
.nv-an-live-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--green);
  display: inline-block;
  animation: nv-pulse 1.8s ease-in-out infinite;
  flex-shrink: 0;
}

.nv-an-live-dot--sm { width: 6px; height: 6px; }

@keyframes nv-pulse {
  0%, 100% { opacity: 1;   transform: scale(1);    box-shadow: 0 0 0 0 rgba(34,197,94,.5); }
  50%       { opacity: .7;  transform: scale(.85);  box-shadow: 0 0 0 5px rgba(34,197,94,0); }
}

/* ── Summary KPI strip ─────────────────────────────────────── */
.nv-an-summary {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 32px;
}

.nv-an-kpi {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--r);
  padding: 22px 20px 18px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  transition: border-color .2s;
}

.nv-an-kpi:hover { border-color: var(--border-md); }

.nv-an-kpi--accent { border-color: rgba(167,139,250,.2); background: rgba(167,139,250,.04); }
.nv-an-kpi--green  { border-color: rgba(34,197,94,.2);  background: rgba(34,197,94,.04); }
.nv-an-kpi--live   { border-color: rgba(200,242,58,.2); background: rgba(200,242,58,.04); }

.nv-an-kpi-num {
  font-size: 38px;
  font-weight: 700;
  color: var(--ink);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -1px;
}

.nv-an-kpi--accent .nv-an-kpi-num { color: var(--purple); }
.nv-an-kpi--green  .nv-an-kpi-num { color: var(--green);  }
.nv-an-kpi--live   .nv-an-kpi-num { color: var(--accent); }

.nv-an-kpi-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--dim);
}

/* ── Per-invitation cards ──────────────────────────────────── */
.nv-an-cards {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.nv-an-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 24px 26px 22px;
  transition: border-color .2s, box-shadow .2s;
}

.nv-an-card:hover { border-color: var(--border-md); }

.nv-an-card--live {
  border-color: rgba(34,197,94,.25);
  box-shadow: 0 0 0 1px rgba(34,197,94,.06) inset,
              0 2px 24px rgba(34,197,94,.06);
}

/* Card header */
.nv-an-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  flex-wrap: wrap;
  gap: 10px;
}

.nv-an-card-title-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.nv-an-card-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--ink);
  margin: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: -.2px;
}

/* Published badge */
.nv-an-pub {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .4px;
  text-transform: uppercase;
  padding: 3px 9px;
  border-radius: 99px;
  white-space: nowrap;
  flex-shrink: 0;
}

.nv-an-pub--live  { background: rgba(34,197,94,.12);  color: var(--green); border: 1px solid rgba(34,197,94,.2); }
.nv-an-pub--draft { background: rgba(139,148,160,.06); color: var(--muted); border: 1px solid var(--border); }

/* Live chip */
.nv-an-live-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--green);
  background: rgba(34,197,94,.08);
  border: 1px solid rgba(34,197,94,.18);
  padding: 5px 12px;
  border-radius: 99px;
  white-space: nowrap;
  transition: opacity .2s;
}

.nv-an-live-chip--dim {
  color: var(--dim);
  background: rgba(255,255,255,.03);
  border-color: var(--border);
}

/* ── Card KPI row ──────────────────────────────────────────── */
.nv-an-card-kpis {
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  margin-bottom: 16px;
  background: var(--card-2);
}

.nv-an-kpi-cell {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 16px 10px 14px;
  border-right: 1px solid var(--border);
  text-align: center;
  background: transparent;
  transition: background .15s;
}

.nv-an-kpi-cell:last-child { border-right: none; }
.nv-an-kpi-cell:hover { background: rgba(255,255,255,.03); }

.nv-an-kpi-cell--green { background: rgba(34,197,94,.04); }
.nv-an-kpi-cell--red   { background: rgba(239,68,68,.04); }
.nv-an-kpi-cell--muted { background: transparent; }

.nv-an-kpi-icon {
  font-size: 14px;
  color: var(--dim);
  margin-bottom: 6px;
}

.nv-an-kpi-cell--green .nv-an-kpi-icon { color: var(--green); }
.nv-an-kpi-cell--red   .nv-an-kpi-icon { color: var(--red); }

.nv-an-kpi-val {
  font-size: 26px;
  font-weight: 700;
  color: var(--ink);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.5px;
  transition: color .2s;
}

.nv-an-kpi-cell--green .nv-an-kpi-val { color: var(--green); }
.nv-an-kpi-cell--red   .nv-an-kpi-val { color: var(--red); }
.nv-an-kpi-cell--muted .nv-an-kpi-val { color: var(--dim); }

.nv-an-kpi-lbl {
  font-size: 9px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--dim);
  margin-top: 5px;
}

/* Flash animation on update */
.nv-an-flash { animation: nv-flash .6s ease; }

@keyframes nv-flash {
  0%   { color: var(--accent); }
  100% { color: inherit; }
}

/* ── Breakdowns ────────────────────────────────────────────── */
.nv-an-card-breakdown {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 16px;
}

.nv-an-bd-col {
  background: var(--card-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.nv-an-bd-title {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--dim);
}

/* Pills */
.nv-an-pill {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 5px 0;
  border-bottom: 1px solid var(--border);
}

.nv-an-pill:last-child { border-bottom: none; }

.nv-an-pill-left {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--mid);
  min-width: 0;
}

.nv-an-pill-left i { font-size: 13px; color: var(--dim); flex-shrink: 0; }
.nv-an-pill-left strong { font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: var(--ink); }

.nv-an-pill-right {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.nv-an-pill-right em {
  font-style: normal;
  font-size: 11px;
  font-family: var(--mono);
  color: var(--muted);
  min-width: 18px;
  text-align: right;
}

.nv-an-pill-track {
  width: 48px;
  height: 3px;
  background: rgba(255,255,255,.07);
  border-radius: 99px;
  overflow: hidden;
}

.nv-an-pill-track span {
  display: block;
  height: 100%;
  background: var(--accent);
  border-radius: 99px;
  transition: width .5s ease;
}

/* ── Sparkline / Last 7 days ───────────────────────────────── */
.nv-an-sparkline-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.nv-an-spark-label {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--dim);
  display: flex;
  align-items: center;
  gap: 5px;
}

.nv-an-sparkline {
  display: flex;
  align-items: flex-end;
  gap: 5px;
  height: 64px;
  background: var(--card-2);
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  padding: 10px 12px;
  overflow: hidden;
}

/* Prevent the black bar — hide when empty or has no bar children */
.nv-an-sparkline:empty,
.nv-an-sparkline-section:empty { display: none; }

.nv-an-sparkline-section:has(.nv-an-sparkline:not(:has(.nv-an-bar-wrap))) {
  display: none;
}

.nv-an-bar-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  flex: 1;
  cursor: default;
}

.nv-an-bar {
  width: 100%;
  background: var(--accent);
  border-radius: 3px 3px 1px 1px;
  min-height: 4px;
  opacity: .5;
  transition: height .4s ease, opacity .15s;
}

.nv-an-bar-wrap:hover .nv-an-bar {
  opacity: 1;
  box-shadow: 0 0 10px rgba(200,242,58,.45);
}

.nv-an-bar-lbl {
  font-size: 8.5px;
  color: var(--dim);
  font-family: var(--mono);
  white-space: nowrap;
}

/* ── No-data / empty ───────────────────────────────────────── */
.nv-an-no-data {
  font-size: 11.5px;
  color: var(--dim);
  font-style: italic;
}

.nv-an-empty {
  text-align: center;
  padding: 56px 24px;
  color: var(--muted);
  font-size: 14px;
}

/* ── Loading ───────────────────────────────────────────────── */
.nv-an-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 72px 24px;
  color: var(--muted);
  font-size: 13.5px;
}

.nv-an-spinner {
  width: 28px;
  height: 28px;
  border: 2px solid var(--border);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: nv-spin .7s linear infinite;
}

@keyframes nv-spin { to { transform: rotate(360deg); } }

/* ══════════════════════════════════════════════════════════════════
   FILTER BAR
   ══════════════════════════════════════════════════════════════════ */
.nv-an-filter-bar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 0 0 28px;
}

.nv-an-filter-btn {
  padding: 7px 18px;
  border-radius: 999px;
  border: 1.5px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: all .18s;
  letter-spacing: .02em;
  font-family: var(--font);
}

.nv-an-filter-btn:hover {
  border-color: var(--border-md);
  color: var(--ink);
  background: rgba(255,255,255,.07);
}

.nv-an-filter-btn--active {
  background: var(--accent);
  border-color: var(--accent);
  color: #0d0f14;
  font-weight: 700;
}

.nv-an-filter-btn--active:hover {
  background: var(--accent-2);
  border-color: var(--accent-2);
  color: #0d0f14;
}

/* ══════════════════════════════════════════════════════════════════
   CARD HEADER ACTIONS (live chip + CSV btn)
   ══════════════════════════════════════════════════════════════════ */
.nv-an-card-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

.nv-an-csv-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 14px;
  border-radius: var(--r-xs);
  border: 1.5px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--muted);
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  transition: all .18s;
  letter-spacing: .04em;
  white-space: nowrap;
  font-family: var(--font);
}

.nv-an-csv-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
  background: rgba(200,242,58,.06);
}

.nv-an-csv-btn:disabled { opacity: .4; cursor: default; }

/* ══════════════════════════════════════════════════════════════════
   EVENT DATE BADGE
   ══════════════════════════════════════════════════════════════════ */
.nv-an-event-date {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11.5px;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: var(--r-xs);
}

.nv-an-event-date--upcoming {
  background: rgba(56,189,248,.08);
  color: var(--blue);
  border: 1px solid rgba(56,189,248,.18);
}

.nv-an-event-date--expired {
  background: rgba(139,148,160,.05);
  color: var(--dim);
  border: 1px solid var(--border);
  text-decoration: line-through;
}

/* ══════════════════════════════════════════════════════════════════
   GEO / LOCATION SECTION
   ══════════════════════════════════════════════════════════════════ */
.nv-an-geo-section {
  margin-top: 18px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
}

.nv-an-geo-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 14px;
}

.nv-an-geo-title {
  font-size: 9.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--dim);
  display: flex;
  align-items: center;
  gap: 5px;
}

.nv-an-geo-coverage {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.nv-an-geo-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 10.5px;
  font-weight: 600;
  padding: 3px 9px;
  border-radius: 999px;
}

.nv-an-geo-badge--browser {
  background: rgba(167,139,250,.1);
  color: var(--purple);
  border: 1px solid rgba(167,139,250,.2);
}

.nv-an-geo-badge--ip {
  background: rgba(56,189,248,.08);
  color: var(--blue);
  border: 1px solid rgba(56,189,248,.16);
}

.nv-an-geo-badge--cov {
  background: rgba(200,242,58,.07);
  color: var(--accent);
  border: 1px solid rgba(200,242,58,.16);
}

.nv-an-geo-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.nv-an-geo-col {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 800px) {
  .nv-an-summary { grid-template-columns: repeat(2, 1fr); }
  .nv-an-card-kpis { flex-wrap: wrap; }
  .nv-an-kpi-cell { flex: 1 1 30%; }
  .nv-an-card-breakdown { grid-template-columns: 1fr; }
}

@media (max-width: 700px) {
  .nv-an-geo-cols { grid-template-columns: 1fr; }
  .nv-an-card-actions { flex-wrap: wrap; }
  .nv-an-card-title-wrap { flex-wrap: wrap; gap: 6px; }
}

@media (max-width: 500px) {
  .nv-an-summary { grid-template-columns: 1fr 1fr; }
  .nv-an-kpi-num { font-size: 28px; }
  .nv-analytics-page { padding: 20px 16px 52px; }
  .nv-an-title { font-size: 26px; }
}
