/* Street Smart Reports — Terminal Theme CSS
   Applied to all pages except home.hbs (which is self-contained) */

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

:root {
  --navy:      #0B1A2B;
  --panel:     #11233A;
  --panel-alt: #0E1E33;
  --border:    #243348;
  --gold:      #C8A84B;
  --gold-dim:  #9A7A35;
  --text:      #F2F5F9;
  --muted:     #7C8AA0;
  --body:      #AEB8C6;
  --faint:     #3D4F66;
  --teal:      #9FE1CB;
  --coral:     #F0997B;
  --mono:      'JetBrains Mono', monospace;
  --sans:      'Space Grotesk', system-ui, sans-serif;
}

html { scroll-behavior: smooth; }

body {
  background: var(--navy);
  color: var(--text);
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

#main { flex: 1; }

/* ── SITE NAV ── */
.site-nav {
  position: sticky; top: 0; z-index: 100;
  background: rgba(11,26,43,0.93);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.site-nav-inner {
  max-width: 1400px; margin: 0 auto;
  padding: 0 clamp(1.5rem,5vw,4rem);
  display: flex; align-items: center;
  justify-content: space-between;
  height: 60px;
}
.site-nav-logo {
  font-family: var(--mono); font-size: 0.78rem;
  font-weight: 400; letter-spacing: 0.08em;
  color: var(--gold); text-decoration: none;
}
.site-nav-logo::before { content: '> '; color: var(--muted); }
.site-nav-links {
  display: flex; align-items: center;
  gap: 2rem; list-style: none;
}
.site-nav-links a {
  font-size: 0.8rem; font-weight: 500;
  letter-spacing: 0.05em; color: var(--muted);
  text-decoration: none; text-transform: uppercase;
  transition: color 0.2s;
}
.site-nav-links a:hover, .site-nav-links a.nav-current { color: var(--text); }
.site-nav-btn {
  display: inline-flex; align-items: center;
  padding: 0.5rem 1.2rem; border-radius: 3px;
  background: var(--gold); color: var(--navy);
  font-family: var(--sans); font-size: 0.8rem;
  font-weight: 600; letter-spacing: 0.04em;
  text-decoration: none; transition: all 0.2s;
}
.site-nav-btn:hover { background: #DEB95C; transform: translateY(-1px); }

/* ── POST HEADER ── */
.post-header {
  border-bottom: 1px solid var(--border);
  padding: clamp(3rem,8vw,6rem) clamp(1.5rem,5vw,4rem) 3rem;
  background: var(--panel-alt);
}
.post-header-inner { max-width: 760px; margin: 0 auto; }

.post-meta {
  display: flex; align-items: center; gap: 0.75rem;
  font-family: var(--mono); font-size: 0.72rem;
  color: var(--muted); margin-bottom: 1.2rem;
  letter-spacing: 0.06em;
}
.post-sep { color: var(--faint); }
.post-tag {
  color: var(--gold); text-decoration: none;
  text-transform: uppercase; letter-spacing: 0.1em;
}
.post-tag:hover { color: #DEB95C; }

.post-title {
  font-size: clamp(1.8rem,4vw,3rem);
  font-weight: 700; letter-spacing: -0.02em;
  color: var(--text); line-height: 1.1;
  margin-bottom: 1rem;
}
.post-excerpt {
  font-size: 1.1rem; color: var(--body);
  line-height: 1.65; max-width: 640px;
}

/* ── PAGE ARTICLE ── */
.page-article .post-header {
  padding: clamp(2.5rem,6vw,5rem) clamp(1.5rem,5vw,4rem) 2.5rem;
}

/* ── POST CONTENT ── */
.post-content {
  max-width: 860px; margin: 0 auto;
  padding: 2rem clamp(1.5rem,5vw,4rem);
  font-size: 1rem; color: var(--body);
  line-height: 1.75;
}

/* Full-width images (report pages) */
.post-content .kg-width-full {
  max-width: 100vw !important;
  width: 100vw !important;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
}
.post-content .kg-width-full img {
  width: 100%;
  max-width: 100%;
  height: auto;
  display: block;
}
.post-content h1,.post-content h2,.post-content h3,
.post-content h4,.post-content h5,.post-content h6 {
  color: var(--text); font-weight: 600;
  letter-spacing: -0.015em; margin: 2.5rem 0 1rem;
  line-height: 1.2;
}
.post-content h2 { font-size: 1.5rem; }
.post-content h3 { font-size: 1.25rem; }
.post-content p { margin-bottom: 1.4rem; }
.post-content a { color: var(--gold); text-decoration: underline; text-underline-offset: 3px; }
.post-content a:hover { color: #DEB95C; }
.post-content strong { color: var(--text); font-weight: 600; }
.post-content em { font-style: italic; }
.post-content blockquote {
  border-left: 3px solid var(--gold);
  padding: 1rem 1.5rem;
  margin: 2rem 0;
  background: var(--panel);
  border-radius: 0 3px 3px 0;
}
.post-content blockquote p { color: var(--body); margin-bottom: 0; }
.post-content pre {
  background: var(--panel); border: 1px solid var(--border);
  border-radius: 4px; padding: 1.25rem;
  overflow-x: auto; margin: 2rem 0;
}
.post-content code {
  font-family: var(--mono); font-size: 0.88em;
  color: var(--teal);
}
.post-content pre code { color: var(--body); }
.post-content img {
  max-width: 100%; height: auto;
  border-radius: 4px; margin: 2rem 0;
  border: 1px solid var(--border);
}
.post-content hr {
  border: none; border-top: 1px solid var(--border);
  margin: 3rem 0;
}
.post-content ul, .post-content ol {
  padding-left: 1.75rem; margin-bottom: 1.4rem;
}
.post-content li { margin-bottom: 0.4rem; }
.post-content table {
  width: 100%; border-collapse: collapse;
  margin: 2rem 0; font-size: 0.9rem;
}
.post-content th {
  background: var(--panel); color: var(--muted);
  font-family: var(--mono); font-size: 0.72rem;
  letter-spacing: 0.08em; text-transform: uppercase;
  padding: 0.6rem 0.9rem; text-align: left;
  border-bottom: 1px solid var(--border);
}
.post-content td {
  padding: 0.6rem 0.9rem;
  border-bottom: 1px solid var(--border);
  color: var(--body);
}
.post-content tr:nth-child(even) td { background: var(--panel-alt); }

/* kg-image full width */
.kg-width-wide { max-width: 1000px; margin-left: auto; margin-right: auto; }
.kg-width-full { max-width: 100%; }

/* ── POST FOOTER ── */
.post-footer { border-top: 1px solid var(--border); padding: 2rem clamp(1.5rem,5vw,4rem); }
.post-footer-inner {
  max-width: 760px; margin: 0 auto;
  display: flex; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: 1rem;
}
.post-disclaimer { font-size: 0.78rem; color: var(--faint); font-style: italic; }
.btn-back {
  font-family: var(--mono); font-size: 0.75rem;
  color: var(--gold); text-decoration: none;
  letter-spacing: 0.06em; transition: color 0.2s;
}
.btn-back:hover { color: #DEB95C; }

/* ── ARCHIVE / POSTS LIST ── */
.archive-header {
  padding: clamp(3rem,8vw,5rem) clamp(1.5rem,5vw,4rem) 2rem;
  border-bottom: 1px solid var(--border);
  background: var(--panel-alt);
}
.archive-header h1 {
  font-family: var(--mono); font-size: 0.75rem;
  letter-spacing: 0.15em; color: var(--gold);
  text-transform: uppercase; margin-bottom: 0.5rem;
}
.archive-header p { font-size: 0.9rem; color: var(--muted); }

.posts-grid {
  max-width: 1200px; margin: 0 auto;
  padding: 3rem clamp(1.5rem,5vw,4rem);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 1.5px;
  background: var(--border);
}

.post-card {
  background: var(--panel);
  transition: background 0.2s;
}
.post-card:hover { background: var(--panel-alt); }
.post-card-link {
  display: flex; flex-direction: column;
  text-decoration: none; height: 100%;
}
.post-card-image {
  height: 180px;
  background-size: cover; background-position: center;
  background-color: var(--panel-alt);
}
.post-card-body { padding: 1.5rem; flex: 1; }
.post-card-meta {
  display: flex; align-items: center; gap: 0.6rem;
  font-family: var(--mono); font-size: 0.68rem;
  color: var(--muted); margin-bottom: 0.75rem;
  letter-spacing: 0.06em;
}
.post-card-tag {
  color: var(--gold); text-transform: uppercase;
  letter-spacing: 0.1em;
}
.post-card-title {
  font-size: 1.15rem; font-weight: 600;
  color: var(--text); line-height: 1.3;
  margin-bottom: 0.6rem; letter-spacing: -0.01em;
}
.post-card-excerpt { font-size: 0.85rem; color: var(--body); line-height: 1.55; }

/* ── PAGINATION ── */
.pagination {
  display: flex; align-items: center; justify-content: center;
  gap: 1rem; padding: 2rem; font-family: var(--mono);
  font-size: 0.75rem; color: var(--muted); letter-spacing: 0.06em;
}
.pagination a {
  color: var(--gold); text-decoration: none; transition: color 0.2s;
}
.pagination a:hover { color: #DEB95C; }

/* ── SITE FOOTER ── */
.site-footer {
  border-top: 1px solid var(--border);
  padding: 2rem clamp(1.5rem,5vw,4rem);
}
.site-footer-inner {
  max-width: 1400px; margin: 0 auto;
  display: flex; flex-wrap: wrap;
  align-items: center; justify-content: space-between; gap: 1rem;
}
.footer-brand { font-family: var(--mono); font-size: 0.72rem; color: var(--gold); letter-spacing: 0.08em; }
.footer-links { display: flex; gap: 1.5rem; list-style: none; }
.footer-links a { font-size: 0.78rem; color: var(--muted); text-decoration: none; transition: color 0.2s; }
.footer-links a:hover { color: var(--body); }
.footer-copy { font-size: 0.72rem; color: var(--faint); }

/* ── GHOST PORTAL ── */
.gh-portal-triggerbtn { display: none !important; } /* hide default portal button; we use our own CTA */

/* ── RESPONSIVE ── */
@media (max-width: 800px) {
  .site-nav-links { display: none; }
  .approach-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .post-footer-inner { flex-direction: column; }
  .posts-grid { grid-template-columns: 1fr; }
}

/* ── REPORT ARCHIVE PAGES ───────────────────────────────────────────────── */

.report-archive-header {
  background: var(--panel-alt);
  border-bottom: 1px solid var(--border);
  padding: clamp(3rem,8vw,5rem) clamp(1.5rem,5vw,4rem) 2.5rem;
}
.report-archive-header-inner {
  max-width: 1400px;
  margin: 0 auto;
}

.report-archive-eyebrow {
  font-family: var(--mono); font-size: 0.7rem;
  letter-spacing: 0.15em; color: var(--gold);
  margin-bottom: 0.75rem;
}
.report-archive-title {
  font-size: clamp(2rem,5vw,3.5rem); font-weight: 700;
  letter-spacing: -0.025em; color: var(--text);
  line-height: 1.05; margin-bottom: 1rem;
}
.report-archive-desc {
  font-size: 1rem; color: var(--body);
  line-height: 1.7; max-width: 700px;
  margin-bottom: 1.5rem;
}
.report-archive-meta {
  display: flex; flex-wrap: wrap;
  align-items: center; gap: 0.5rem;
  font-family: var(--mono); font-size: 0.72rem;
  margin-bottom: 1.5rem;
}
.ram-item { color: var(--body); }
.ram-key  { color: var(--muted); margin-right: 0.4rem; }
.ram-sep  { color: var(--faint); }

/* Posts list */
.report-posts-wrap {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2.5rem clamp(1.5rem,5vw,4rem);
}
.access-notice {
  display: flex; align-items: flex-start; gap: 0.75rem;
  background: var(--panel); border: 1px solid var(--border);
  border-left: 3px solid var(--gold);
  padding: 0.9rem 1.1rem;
  border-radius: 0 3px 3px 0;
  font-size: 0.85rem; color: var(--body); line-height: 1.5;
  max-width: 860px;
}
.access-notice-icon { font-size: 1rem; flex-shrink: 0; margin-top: 0.05rem; }
.access-notice-link { color: var(--teal); text-decoration: underline; text-underline-offset: 3px; }
.access-notice-link:hover { color: #b8f0e0; }
.access-notice-link-gold { color: var(--gold) !important; }
.access-notice-link-gold:hover { color: #DEB95C !important; }

/* Posts list */
.report-posts-wrap {
  max-width: 1400px;
  margin: 0 auto;
  padding: 2.5rem clamp(1.5rem,5vw,4rem);
}
.report-posts-grid {
  display: flex; flex-direction: column;
  border: 1px solid var(--border);
}
.no-posts {
  padding: 3rem; font-family: var(--mono);
  font-size: 0.8rem; color: var(--muted);
}

/* Report post card */
.rpc { border-bottom: 1px solid var(--border); }
.rpc:last-child { border-bottom: none; }
.rpc-link {
  display: block; text-decoration: none;
  padding: 1.4rem 1.6rem;
  transition: background 0.15s;
}
.rpc-link:hover { background: var(--panel); }
.rpc-top { display: flex; align-items: center; justify-content: space-between; gap: 1.5rem; }
.rpc-left { flex: 1; min-width: 0; }
.rpc-right { display: flex; align-items: center; gap: 0.9rem; flex-shrink: 0; }

.rpc-date {
  font-family: var(--mono); font-size: 0.68rem;
  color: var(--muted); letter-spacing: 0.08em;
  display: block; margin-bottom: 0.35rem;
}
.rpc-title {
  font-size: 1.05rem; font-weight: 600;
  color: var(--text); line-height: 1.3;
  letter-spacing: -0.01em; margin-bottom: 0.3rem;
}
.rpc-excerpt {
  font-size: 0.83rem; color: var(--muted);
  line-height: 1.5; white-space: nowrap;
  overflow: hidden; text-overflow: ellipsis;
  max-width: 520px;
}

.rpc-badge {
  font-family: var(--mono); font-size: 0.62rem;
  letter-spacing: 0.12em; padding: 0.2rem 0.55rem;
  border-radius: 2px; font-weight: 500; flex-shrink: 0;
}
.rpc-badge-paid    { background: rgba(200,168,75,0.12); color: var(--gold); border: 1px solid rgba(200,168,75,0.3); }
.rpc-badge-members { background: rgba(159,225,203,0.1); color: var(--teal); border: 1px solid rgba(159,225,203,0.25); }
.rpc-badge-free    { background: rgba(93,107,130,0.2);  color: var(--muted); border: 1px solid var(--border); }

.rpc-arrow { font-size: 0.9rem; color: var(--faint); transition: color 0.15s; }
.rpc-link:hover .rpc-arrow { color: var(--gold); }

/* Pagination for report pages */
.report-pagination {
  padding: 1.5rem 0; border-top: 1px solid var(--border);
  font-family: var(--mono); font-size: 0.75rem; color: var(--muted);
  letter-spacing: 0.06em; display: flex; gap: 1.5rem;
}
.report-pagination a { color: var(--gold); text-decoration: none; }
.report-pagination a:hover { color: #DEB95C; }

/* Ghost paywall card */
.gh-post-upgrade-cta {
  background: var(--panel) !important;
  border: 1px solid var(--border) !important;
  border-top: 3px solid var(--gold) !important;
  color: var(--body) !important;
}
.gh-post-upgrade-cta h2 { color: var(--text) !important; }

@media (max-width: 600px) {
  .rpc-excerpt { display: none; }
  .report-archive-meta { flex-direction: column; align-items: flex-start; }
  .ram-sep { display: none; }
}

/* ── PAYWALL ──────────────────────────────────────────────────────────────── */
.post-paywall {
  max-width: 760px; margin: 0 auto;
  padding: 3rem clamp(1.5rem,5vw,4rem);
}
.paywall-box {
  background: var(--panel);
  border: 1px solid var(--border);
  border-top: 3px solid var(--gold);
  padding: 2.5rem;
  text-align: center;
}
.paywall-eyebrow {
  font-family: var(--mono); font-size: 0.7rem;
  letter-spacing: 0.15em; color: var(--gold);
  margin-bottom: 0.75rem;
}
.paywall-title {
  font-size: 1.4rem; font-weight: 700;
  color: var(--text); margin-bottom: 0.75rem;
  letter-spacing: -0.01em; line-height: 1.2;
}
.paywall-desc {
  font-size: 0.92rem; color: var(--body);
  line-height: 1.65; max-width: 480px;
  margin: 0 auto 2rem;
}
.paywall-actions {
  display: flex; align-items: center;
  justify-content: center; gap: 1rem;
  margin-bottom: 1rem; flex-wrap: wrap;
}
.btn-paywall-gold {
  display: inline-flex; align-items: center;
  padding: 0.65rem 1.5rem; border-radius: 3px;
  background: var(--gold); color: var(--navy);
  font-family: var(--sans); font-size: 0.9rem;
  font-weight: 600; letter-spacing: 0.03em;
  text-decoration: none; transition: all 0.2s;
}
.btn-paywall-gold:hover { background: #DEB95C; transform: translateY(-1px); }
.btn-paywall-outline {
  display: inline-flex; align-items: center;
  padding: 0.65rem 1.5rem; border-radius: 3px;
  background: transparent; color: var(--gold);
  border: 1px solid var(--gold-dim);
  font-family: var(--sans); font-size: 0.9rem;
  font-weight: 500; text-decoration: none;
  transition: all 0.2s;
}
.btn-paywall-outline:hover { background: rgba(200,168,75,0.08); }
.paywall-fine {
  font-size: 0.78rem; color: var(--muted);
}
.paywall-fine a { color: var(--gold); text-decoration: underline; }

/* ── LEGAL DISCLAIMER FOOTER ─────────────────────────────────────────────── */
.site-footer-disclaimer {
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 1rem clamp(1.5rem,5vw,4rem);
  font-size: 0.72rem;
  color: var(--gold);
  line-height: 1.6;
  text-align: center;
  max-width: 1400px;
  margin: 0 auto;
}

/* Home page footer layout */
.home-footer-disclaimer {
  border-top: 1px solid var(--border);
  padding: 1rem clamp(1.5rem,5vw,4rem) 0.75rem;
  font-size: 0.72rem;
  color: var(--gold);
  line-height: 1.6;
  text-align: center;
}
.home-footer-inner {
  padding: 1.5rem clamp(1.5rem,5vw,4rem);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
