/* Pulsweise Analytics — editorial dashboard
   Brand: Navy / Gold / Cream, Cormorant Garamond + Manrope + JetBrains Mono
*/

:root {
  --navy-900: #0A1E3F;
  --navy-700: #102A55;
  --navy-500: #1E3D70;
  --gold-700: #A6864A;
  --gold-500: #C9A961;
  --gold-300: #E8D6A6;
  --cream:    #FAF8F2;
  --cream-2:  #F2EEE3;
  --ink:      #1B1B1F;
  --ink-soft: #5C5B57;
  --hairline: rgba(166, 134, 74, 0.28);

  --serif:  'Cormorant Garamond', Georgia, serif;
  --sans:   'Manrope', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --mono:   'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;
}

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

html, body { margin: 0; padding: 0; background: var(--cream); color: var(--ink); font-family: var(--sans); font-size: 16px; line-height: 1.55; }
body { min-height: 100vh; display: flex; flex-direction: column; -webkit-font-smoothing: antialiased; }

a { color: var(--navy-900); text-decoration: none; }
a:hover { color: var(--gold-700); }

main { flex: 1; max-width: 1280px; width: 100%; margin: 0 auto; padding: 32px 28px 64px; }

/* ── Masthead ───────────────────────────────────────────── */
.masthead {
  background: var(--navy-900);
  color: var(--cream);
  border-bottom: 1px solid rgba(201, 169, 97, 0.3);
}
.masthead-inner {
  max-width: 1280px; margin: 0 auto;
  display: flex; align-items: center; gap: 24px;
  padding: 18px 28px;
}
.logo { display: inline-flex; align-items: center; gap: 12px; color: var(--cream); font-family: var(--serif); font-size: 22px; }
.logo:hover { color: var(--gold-300); }
.logo-mark { width: 32px; height: 32px; flex: none; }
.logo-words em { font-style: italic; color: var(--gold-500); font-weight: 600; }
.topnav { margin-left: 12px; display: flex; gap: 18px; flex: 1; }
.topnav a {
  color: var(--cream);
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.15em;
  padding: 6px 0; border-bottom: 1px solid transparent;
}
.topnav a:hover, .topnav a.active { color: var(--gold-300); border-bottom-color: var(--gold-500); }
.api-key-slot { margin-left: auto; }

/* ── Buttons ─────────────────────────────────────────────── */
.ghost-btn, .primary-btn {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.12em;
  padding: 8px 14px;
  border: 1px solid var(--gold-500);
  background: transparent; color: var(--cream);
  cursor: pointer;
  transition: background-color 0.18s ease, color 0.18s ease;
}
.masthead .ghost-btn:hover { background: var(--gold-500); color: var(--navy-900); }
.primary-btn { background: var(--gold-500); color: var(--navy-900); }
.primary-btn:hover { background: var(--gold-300); }

main .ghost-btn { color: var(--navy-900); border-color: var(--navy-900); }
main .ghost-btn:hover { background: var(--navy-900); color: var(--cream); }

/* ── Cards & sections ──────────────────────────────────── */
.section { margin-bottom: 48px; }
.section-eyebrow {
  font-family: var(--mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.22em;
  color: var(--gold-700);
  margin: 0 0 6px;
}
.section-title {
  font-family: var(--serif); font-size: 38px;
  font-weight: 500; line-height: 1.15;
  margin: 0 0 8px; color: var(--navy-900);
}
.section-title em { color: var(--gold-700); font-weight: 500; }
.section-lede {
  font-family: var(--serif); font-size: 19px;
  color: var(--ink-soft); font-style: italic;
  max-width: 640px; margin: 0 0 28px;
}

.card {
  background: #fff;
  border: 1px solid var(--hairline);
  padding: 24px 26px;
  border-radius: 4px;
}
.card + .card { margin-top: 20px; }

/* ── Stats ───────────────────────────────────────────────── */
.stats-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0;
  border: 1px solid var(--hairline);
  background: #fff;
}
.stat {
  padding: 22px 26px;
  border-right: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
}
.stat:last-child { border-right: none; }
.stat-label {
  font-family: var(--mono); font-size: 10px;
  text-transform: uppercase; letter-spacing: 0.18em;
  color: var(--ink-soft);
  margin-bottom: 8px;
}
.stat-value {
  font-family: var(--mono); font-size: 32px;
  font-weight: 500; line-height: 1; color: var(--navy-900);
  font-variant-numeric: tabular-nums;
}
.stat-delta { font-family: var(--mono); font-size: 12px; margin-top: 6px; }
.stat-delta.up { color: #2E6F4F; }
.stat-delta.down { color: #8E3838; }

/* ── Tables ──────────────────────────────────────────────── */
table.editorial {
  width: 100%; border-collapse: collapse; background: #fff;
  border: 1px solid var(--hairline);
  font-size: 14px;
}
table.editorial th, table.editorial td {
  padding: 10px 16px;
  text-align: left;
  border-bottom: 1px solid var(--hairline);
}
table.editorial th {
  font-family: var(--mono); font-size: 10px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.16em;
  color: var(--gold-700);
  background: var(--cream-2);
}
table.editorial td.num { font-family: var(--mono); text-align: right; font-variant-numeric: tabular-nums; }
table.editorial tr:last-child td { border-bottom: none; }
table.editorial tbody tr:hover { background: rgba(232, 214, 166, 0.18); }

/* ── Charts ──────────────────────────────────────────────── */
.chart {
  width: 100%; height: 240px;
  background: #fff;
  border: 1px solid var(--hairline);
  padding: 20px;
  border-radius: 4px;
}
.chart svg { width: 100%; height: 100%; display: block; }

/* ── Site list ──────────────────────────────────────────── */
.sites-list { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 18px; }
.site-card {
  background: #fff; border: 1px solid var(--hairline); padding: 22px 24px;
  border-radius: 4px; transition: border-color 0.18s ease;
  display: flex; flex-direction: column; gap: 8px;
}
.site-card:hover { border-color: var(--gold-500); }
.site-card .site-name { font-family: var(--serif); font-size: 26px; font-weight: 500; color: var(--navy-900); line-height: 1.1; }
.site-card .site-domain { font-family: var(--mono); font-size: 11px; color: var(--ink-soft); }
.site-card .site-meta { margin-top: 6px; font-family: var(--mono); font-size: 11px; color: var(--gold-700); text-transform: uppercase; letter-spacing: 0.12em; }

/* ── Sub-nav for site pages ─────────────────────────────── */
.subnav { display: flex; gap: 0; margin: 0 0 28px; border-bottom: 1px solid var(--hairline); }
.subnav a {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.14em;
  padding: 12px 18px; color: var(--ink-soft);
  border-bottom: 2px solid transparent;
}
.subnav a:hover { color: var(--navy-900); }
.subnav a.active { color: var(--navy-900); border-bottom-color: var(--gold-500); }

/* ── Realtime pulse ────────────────────────────────────── */
.pulse-dot {
  display: inline-block; width: 10px; height: 10px; border-radius: 50%;
  background: var(--gold-500); margin-right: 8px;
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(201, 169, 97, 0.55); }
  50% { box-shadow: 0 0 0 10px rgba(201, 169, 97, 0); }
}

/* ── AI insight ─────────────────────────────────────────── */
.insight-headline {
  font-family: var(--serif); font-size: 32px; font-weight: 500; line-height: 1.18;
  color: var(--navy-900); margin: 0 0 16px;
}
.insight-headline em { color: var(--gold-700); }
.insight-meta {
  font-family: var(--mono); font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.12em; color: var(--ink-soft);
  margin-bottom: 22px;
}
.insight-body { font-size: 16px; line-height: 1.65; max-width: 720px; }
.insight-body p { margin: 0 0 14px; }
.insight-body strong { color: var(--navy-900); }
.recommendation {
  background: #fff; border-left: 3px solid var(--gold-500);
  padding: 16px 22px; margin: 14px 0;
}
.rec-title { font-family: var(--serif); font-size: 20px; font-weight: 600; color: var(--navy-900); margin: 0 0 4px; }
.rec-rationale { font-size: 14px; color: var(--ink-soft); margin: 0; }
.rec-effort {
  display: inline-block;
  font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.14em;
  padding: 2px 8px; margin-left: 8px;
  background: var(--cream-2); color: var(--ink-soft);
}

/* ── Dialog ─────────────────────────────────────────────── */
dialog {
  border: 1px solid var(--gold-500); background: var(--cream);
  padding: 28px; max-width: 460px; border-radius: 4px;
}
dialog::backdrop { background: rgba(10, 30, 63, 0.55); }
dialog h3 { font-family: var(--serif); font-size: 28px; margin: 0 0 8px; color: var(--navy-900); }
dialog .dialog-lead { color: var(--ink-soft); font-size: 14px; margin-bottom: 18px; }
dialog input[type=password], dialog input[type=text] {
  width: 100%; padding: 10px 12px; font-family: var(--mono); font-size: 13px;
  border: 1px solid var(--hairline); background: #fff;
}
dialog .dialog-line { display: block; font-family: var(--mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.14em; color: var(--ink-soft); margin-top: 16px; }
dialog .dialog-line input { margin-top: 6px; }
dialog .dialog-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 22px; }
dialog button { color: var(--navy-900); border-color: var(--navy-900); }

/* ── Footer ─────────────────────────────────────────────── */
.footer {
  border-top: 1px solid var(--hairline);
  background: var(--cream-2);
}
.footer-inner {
  max-width: 1280px; margin: 0 auto; padding: 22px 28px;
  display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 14px;
  font-family: var(--mono); font-size: 11px; color: var(--ink-soft);
  text-transform: uppercase; letter-spacing: 0.14em;
}
.footer-quote { font-family: var(--serif); font-style: italic; font-size: 15px; text-transform: none; letter-spacing: 0; color: var(--ink-soft); }

/* ── Misc ───────────────────────────────────────────────── */
.mono { font-family: var(--mono); font-size: 12px; color: var(--ink-soft); }
.loading { padding: 80px 0; text-align: center; }
.error-banner {
  background: #fff7f0; border: 1px solid #d39a7a; color: #6e2b14;
  padding: 14px 18px; margin: 20px 0; border-radius: 4px;
  font-size: 14px;
}
.empty-state {
  text-align: center; padding: 60px 24px;
  color: var(--ink-soft); font-style: italic;
}

/* ── Responsive ─────────────────────────────────────────── */
@media (max-width: 768px) {
  main { padding: 22px 16px 48px; }
  .section-title { font-size: 30px; }
  .stat-value { font-size: 26px; }
  .topnav { display: none; }
  .footer-inner { flex-direction: column; align-items: flex-start; }
}
