/* ============================================================
   CD3WD Project — Shared Article Stylesheet
   Applied to all article pages site-wide
   ============================================================ */

/* --- Google Fonts --- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap');

/* --- CSS Variables --- */
:root {
  --blue-900: #0d1b2e;
  --blue-800: #122338;
  --blue-700: #1a3a5c;
  --blue-600: #1e4d7b;
  --blue-500: #1565c0;
  --blue-400: #1976d2;
  --blue-300: #42a5f5;
  --blue-200: #90caf9;
  --blue-100: #e3f2fd;
  --blue-50:  #f0f8ff;
  --accent:   #ff8f00;
  --accent-light: #fff3e0;
  --text-main: #1a2332;
  --text-muted: #5a6a7e;
  --border: #dde8f0;
  --radius: 8px;
  --shadow: 0 2px 8px rgba(21,101,192,.1);
  --font: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, sans-serif;
}

/* ============================================================
   GLOBAL RESET & TYPOGRAPHY
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

/* Override EVERYTHING to use Inter — catches inline styles, FONT tags, MSO styles */
html, body,
body *, body *::before, body *::after,
font, font *, b, i, u, s, em, strong,
p, li, td, th, div, span, section, article, aside,
blockquote, caption, label, input, textarea,
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font) !important;
}

body {
  background: #f5f8fc !important;
  color: var(--text-main) !important;
  line-height: 1.75 !important;
  font-size: 1rem !important;
  margin: 0 !important;
  padding: 0 !important;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--text-main) !important;
  line-height: 1.35 !important;
  font-weight: 700 !important;
  margin-top: 1.4em !important;
  margin-bottom: .5em !important;
}

h1 { font-size: 1.5rem !important; font-weight: 800 !important; }
h2 { font-size: 1.25rem !important; }
h3 { font-size: 1.1rem !important; color: var(--blue-700) !important; }
h4, h5, h6 { font-size: 1rem !important; }

p { margin-bottom: .9em !important; }

a { color: var(--blue-500) !important; text-decoration: none !important; }
a:hover { color: var(--blue-400) !important; text-decoration: underline !important; }

img { max-width: 100% !important; height: auto !important; }

/* ============================================================
   NUCLEAR FONT OVERRIDE
   Kills <FONT FACE="..."> and MSO inline font declarations
   ============================================================ */
font[face], font[FACE] {
  font-family: var(--font) !important;
  font-size: 1rem !important;
}

/* Also wipe inline style="font-family:Courier..." via specificity */
[style*="font-family"] { font-family: var(--font) !important; }
[style*="FONT-FAMILY"] { font-family: var(--font) !important; }
[style*="font-size:10"] { font-size: 1rem !important; }
[style*="font-size:8"]  { font-size: .9rem !important; }
[style*="FONT-SIZE:10"] { font-size: 1rem !important; }

/* ============================================================
   NAV BAR
   ============================================================ */
.cd3wd-nav {
  background: var(--blue-900) !important;
  padding: 0 24px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  height: 60px !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  box-shadow: 0 2px 12px rgba(0,0,0,.35) !important;
  gap: 12px !important;
}

.cd3wd-nav .nav-logo {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  text-decoration: none !important;
  color: #fff !important;
  flex-shrink: 0 !important;
}
.cd3wd-nav .nav-logo img {
  height: 34px !important;
  width: auto !important;
  border-radius: 4px !important;
}
.cd3wd-nav .nav-logo .nav-site-name {
  display: flex !important;
  flex-direction: column !important;
  line-height: 1.2 !important;
}
.cd3wd-nav .nav-logo .nav-site-name strong {
  font-size: .95rem !important;
  font-weight: 700 !important;
  color: #fff !important;
}
.cd3wd-nav .nav-logo .nav-site-name small {
  font-size: .65rem !important;
  color: var(--blue-200) !important;
  font-weight: 400 !important;
  letter-spacing: .3px !important;
}

.cd3wd-nav .nav-links {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  flex-wrap: nowrap !important;
}
.cd3wd-nav .nav-links a {
  color: var(--blue-200) !important;
  text-decoration: none !important;
  font-size: .8rem !important;
  font-weight: 500 !important;
  padding: 6px 12px !important;
  border-radius: 20px !important;
  border: 1px solid transparent !important;
  transition: all .2s !important;
  white-space: nowrap !important;
}
.cd3wd-nav .nav-links a:hover {
  background: var(--blue-700) !important;
  color: #fff !important;
  border-color: var(--blue-600) !important;
  text-decoration: none !important;
}
.cd3wd-nav .nav-links a.nav-donate {
  background: var(--accent) !important;
  color: #fff !important;
  font-weight: 700 !important;
  border-color: transparent !important;
  padding: 6px 14px !important;
}
.cd3wd-nav .nav-links a.nav-donate:hover {
  background: #e65100 !important;
  color: #fff !important;
}

@media (max-width: 600px) {
  .cd3wd-nav { height: auto !important; padding: 10px 16px !important; flex-wrap: wrap !important; gap: 8px !important; }
  .cd3wd-nav .nav-logo .nav-site-name small { display: none !important; }
  .cd3wd-nav .nav-links a { font-size: .75rem !important; padding: 5px 9px !important; }
}

/* ============================================================
   PAGE LAYOUT — wraps all body content after the nav
   ============================================================ */

/* The .page-wrap div is injected by the cleanup script around body content */
.page-wrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 28px 20px 80px;
}

/* Fallback: if no .page-wrap, constrain body itself */
body > *:not(.cd3wd-nav):not(script):not(style) {
  max-width: 900px;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* ============================================================
   ARTICLE CONTENT CARDS (rebuilt CD3WD articles)
   ============================================================ */

/* Article wrapper */
.article-wrap {
  max-width: 900px;
  margin: 0 auto;
  padding: 28px 20px 80px;
}

/* Article header card */
.article-header {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 24px 28px !important;
  margin-bottom: 24px !important;
  box-shadow: var(--shadow) !important;
}
.article-header h1 {
  font-size: 1.4rem !important;
  font-weight: 800 !important;
  color: var(--text-main) !important;
  line-height: 1.3 !important;
  margin-bottom: 8px !important;
  margin-top: 0 !important;
}
.article-header .meta {
  font-size: .82rem !important;
  color: var(--text-muted) !important;
}

/* Article content area */
.article-content, .ch, .chapter-section {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 28px 32px !important;
  box-shadow: var(--shadow) !important;
  margin-bottom: 16px !important;
}

/* ============================================================
   VITA / LEGACY WORD HTML CONTENT CARD
   Applied to .Section1, .WordSection1, etc. and the
   .vita-content div injected by the cleanup script
   ============================================================ */

.vita-content,
div[class*="Section"],
div[class*="section"],
.Section1, .WordSection1, .Section2, .WordSection2 {
  background: #fff !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius) !important;
  padding: 28px 32px !important;
  box-shadow: var(--shadow) !important;
  margin: 0 auto 24px !important;
  max-width: 900px !important;
}

/* Language navigation bar (VITA multi-language links) */
.lang-nav {
  background: var(--blue-50) !important;
  border: 1px solid var(--blue-200) !important;
  border-radius: var(--radius) !important;
  padding: 10px 16px !important;
  margin: 0 auto 16px !important;
  max-width: 900px !important;
  font-size: .82rem !important;
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  flex-wrap: wrap !important;
}
.lang-nav a {
  color: var(--blue-500) !important;
  font-size: .82rem !important;
  padding: 3px 8px !important;
  border-radius: 12px !important;
  border: 1px solid var(--blue-200) !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  transition: background .15s !important;
}
.lang-nav a:hover {
  background: var(--blue-100) !important;
  text-decoration: none !important;
}

/* ============================================================
   LEGACY JUNK — hide old nav remnants injected by Word/framesets
   ============================================================ */
.auto-style1,
.auto-style2,
.auto-style3 {
  display: none !important;
}

/* Hide stray horizontal rules immediately after nav */
.cd3wd-nav + hr,
.cd3wd-nav + HR,
.cd3wd-nav ~ center:first-of-type {
  display: none !important;
}

/* ============================================================
   TABLE OF CONTENTS
   ============================================================ */
.toc {
  background: var(--blue-50) !important;
  border: 1px solid var(--blue-200) !important;
  border-radius: var(--radius) !important;
  padding: 16px 20px !important;
  margin-bottom: 24px !important;
}
.toc h2 {
  font-size: .85rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .5px !important;
  color: var(--text-muted) !important;
  margin-bottom: 10px !important;
  margin-top: 0 !important;
}
.toc a { color: var(--blue-500) !important; font-size: .875rem !important; }
.toc a:hover { text-decoration: underline !important; color: var(--blue-400) !important; }

/* ============================================================
   TABLES
   ============================================================ */
table {
  border-collapse: collapse !important;
  width: 100% !important;
  margin: 16px 0 !important;
  font-size: .9rem !important;
  display: block !important;
  overflow-x: auto !important;
}
td, th {
  border: 1px solid var(--border) !important;
  padding: 8px 12px !important;
  vertical-align: top !important;
}
th {
  background: var(--blue-50) !important;
  font-weight: 600 !important;
  color: var(--blue-700) !important;
}

/* ============================================================
   LEGACY WORD HTML CLEANUP (MsoNormal etc.)
   ============================================================ */
.MsoNormal, li.MsoNormal, p.MsoNormal,
.MsoBodyText, .MsoHeading1, .MsoHeading2,
.MsoHeading3, .MsoTitle, .MsoSubtitle,
[class*="Mso"] {
  font-family: var(--font) !important;
  font-size: 1rem !important;
  line-height: 1.75 !important;
  margin-bottom: .6em !important;
  color: var(--text-main) !important;
}
o\:p { display: none !important; }
/* Kill MSO margin:0 overrides */
p.MsoNormal, p[class*="Mso"] {
  margin-bottom: .7em !important;
}

/* ============================================================
   MISC
   ============================================================ */

/* Unavailable stub */
.unavail {
  text-align: center !important;
  padding: 48px 20px !important;
  color: var(--text-muted) !important;
}

/* Back-to-top */
.btt {
  display: block !important;
  text-align: center !important;
  margin-top: 24px !important;
  color: var(--blue-500) !important;
  text-decoration: none !important;
  font-size: .85rem !important;
}
.btt:hover { text-decoration: underline !important; }

/* Blockquotes */
blockquote {
  border-left: 3px solid var(--blue-300) !important;
  padding: 8px 16px !important;
  margin: 12px 0 !important;
  color: var(--text-muted) !important;
  font-style: italic !important;
}

/* Pre / code */
pre, code {
  font-family: 'Courier New', Courier, monospace !important;
  background: var(--blue-50) !important;
  padding: 2px 6px !important;
  border-radius: 3px !important;
  font-size: .85rem !important;
}

/* HR */
hr, HR {
  border: none !important;
  border-top: 1px solid var(--border) !important;
  margin: 20px 0 !important;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 700px) {
  .page-wrap, .article-wrap { padding: 16px 12px 48px !important; }
  .article-content, .ch, .chapter-section,
  .vita-content, div[class*="Section"] {
    padding: 18px 16px !important;
  }
  .article-header { padding: 16px !important; }
  h1 { font-size: 1.25rem !important; }
  h2 { font-size: 1.1rem !important; }
}
