/* Shared styles for content pages (about, privacy, terms, guides) */
/* Matches the VV Builder dark/space aesthetic */

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

html, body {
  background: radial-gradient(ellipse at top, #0a1428 0%, #050a14 60%, #02050d 100%);
  color: #c5d6ec;
  font-family: 'Exo 2', system-ui, -apple-system, sans-serif;
  line-height: 1.7;
  min-height: 100vh;
}

.content-wrap {
  max-width: 820px;
  margin: 0 auto;
  padding: 60px 28px 80px;
}

/* Top nav */
.site-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  align-items: center;
  padding: 20px 28px;
  border-bottom: 1px solid rgba(80, 170, 255, 0.12);
  background: rgba(5, 10, 20, 0.6);
  backdrop-filter: blur(8px);
  position: sticky;
  top: 0;
  z-index: 50;
}
.site-nav .brand {
  font-family: 'Cinzel', serif;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: #b4ebff;
  text-decoration: none;
}
.site-nav .brand:hover { color: #ffffff; }
.site-nav a {
  color: rgba(180, 205, 235, 0.75);
  text-decoration: none;
  font-size: 14px;
  letter-spacing: 0.05em;
  transition: color 0.2s;
}
.site-nav a:hover { color: #b4ebff; }
.site-nav .spacer { flex: 1; }

/* Headings */
h1 {
  font-family: 'Cinzel', serif;
  font-weight: 700;
  font-size: 36px;
  letter-spacing: 0.08em;
  color: #ffffff;
  margin-bottom: 12px;
  line-height: 1.2;
}
h2 {
  font-family: 'Cinzel', serif;
  font-weight: 600;
  font-size: 24px;
  letter-spacing: 0.06em;
  color: #b4ebff;
  margin: 40px 0 14px;
}
h3 {
  font-family: 'Exo 2', sans-serif;
  font-weight: 700;
  font-size: 18px;
  color: #d9e7f7;
  margin: 28px 0 10px;
  letter-spacing: 0.02em;
}
.subtitle {
  color: rgba(180, 205, 235, 0.6);
  font-size: 15px;
  margin-bottom: 36px;
  font-style: italic;
}

/* Body */
p {
  margin: 0 0 16px;
  color: rgba(197, 214, 236, 0.92);
  font-size: 15.5px;
}
strong { color: #ffffff; }
em { color: #b4ebff; }

ul, ol { margin: 0 0 20px 24px; }
li { margin-bottom: 8px; color: rgba(197, 214, 236, 0.92); }

a { color: #80d4ff; text-decoration: none; }
a:hover { color: #b4ebff; text-decoration: underline; }

/* Faction cards on guides index */
.guide-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 18px;
  margin: 30px 0;
}
.guide-card {
  display: block;
  padding: 20px;
  background: rgba(10, 22, 45, 0.6);
  border: 1px solid rgba(80, 170, 255, 0.18);
  border-radius: 4px;
  transition: all 0.2s;
}
.guide-card:hover {
  border-color: rgba(80, 210, 255, 0.5);
  background: rgba(15, 30, 60, 0.8);
  text-decoration: none;
  transform: translateY(-2px);
}
.guide-card .gc-title {
  font-family: 'Cinzel', serif;
  font-weight: 600;
  font-size: 16px;
  color: #b4ebff;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.guide-card .gc-desc {
  font-size: 13.5px;
  color: rgba(180, 205, 235, 0.7);
  line-height: 1.5;
}

/* Callout box */
.callout {
  margin: 24px 0;
  padding: 16px 20px;
  background: rgba(20, 50, 90, 0.4);
  border-left: 3px solid #50d2ff;
  border-radius: 2px;
}
.callout p { margin: 0; }

/* Footer */
.site-footer {
  margin-top: 60px;
  padding: 24px 28px;
  border-top: 1px solid rgba(80, 170, 255, 0.12);
  background: rgba(5, 10, 20, 0.6);
  text-align: center;
  color: rgba(180, 205, 235, 0.55);
  font-size: 13px;
}
.site-footer a { margin: 0 10px; }

/* Back link */
.back-link {
  display: inline-block;
  margin-bottom: 24px;
  color: rgba(180, 205, 235, 0.65);
  font-size: 13px;
  letter-spacing: 0.05em;
}
.back-link:hover { color: #b4ebff; }

/* Responsive */
@media (max-width: 600px) {
  h1 { font-size: 28px; }
  h2 { font-size: 20px; }
  .content-wrap { padding: 40px 18px 60px; }
  .site-nav { padding: 14px 18px; gap: 12px; }
  .site-nav .brand { font-size: 15px; }
  .site-nav a { font-size: 13px; }
}