/* ============================================================
   DARKSAINT GAMES — UNIFIED FATED-REALM SITE THEME
   ============================================================
   This stylesheet is loaded AFTER style.css / site-chrome.css on
   every page and rewrites the visual identity of the entire site
   to match the Fated Realm cover aesthetic: near-black canvas,
   warm old-wood accents, ash-white serif display, muted sans for
   labels, and long letter-spaced uppercase lockups.

   It is aggressive on purpose (uses !important on identity-level
   rules) so individual pages and inline <style> blocks cannot
   drift the palette or typography out of alignment. Layout and
   structural rules are left alone so doc pages keep their grids,
   sidebars, tables, and code blocks intact.
   ============================================================ */

:root {
  /* Core FR palette (match FatedRealm-Cover.html) */
  --fr-ash:        #F0ECE6;
  --fr-text:       #c8c4bc;
  --fr-text2:      #7a7570;
  --fr-dead-stone: #7A7570;
  --fr-old-wood:   #4A3B2E;
  --fr-deep-ash:   #1a1714;
  --fr-near-black: #0d0c0a;
  --fr-black:      #080706;

  --fr-mark:       #D4E0E8;
  --fr-mark-dim:   #8faabf;
  --fr-gold:       #c8a84a;

  --fr-teal:       #4a9080;
  --fr-green:      #4a6a3a;
  --fr-blue:       #3a5a7a;
  --fr-red:        #7a2020;

  --fr-serif:      'Georgia', 'Times New Roman', serif;
  --fr-sans:       -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;

  --fr-line:       rgba(212, 224, 232, 0.08);
  --fr-line-2:     rgba(212, 224, 232, 0.18);
  --fr-line-3:     rgba(212, 224, 232, 0.32);
}

/* ============================================================
   BASE — body canvas, typography defaults
============================================================ */
html { scroll-behavior: smooth; }

body {
  background: var(--fr-near-black) !important;
  color: var(--fr-text) !important;
  font-family: var(--fr-serif) !important;
  line-height: 1.7;
}

/* Subtle ambient background overlay: a whisper of grid + warm
   light from the top. Negative z-index so it sits behind normal
   flow without disturbing sticky nav/sidebar stacking. */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background-image:
    linear-gradient(rgba(212, 224, 232, 0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212, 224, 232, 0.022) 1px, transparent 1px);
  background-size: 60px 60px;
}
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background:
    radial-gradient(ellipse 120% 60% at 50% 0%, rgba(74, 59, 46, 0.14) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 50% 100%, rgba(212, 224, 232, 0.025) 0%, transparent 60%);
}

/* Global link defaults */
a { color: var(--fr-mark-dim); transition: color .2s ease; }
a:hover { color: var(--fr-mark); }

strong, b { color: var(--fr-ash); font-weight: 500; }
em, i { color: var(--fr-text); }

/* ------ Headings — serif, uppercase, ash ------ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.04em !important;
}

/* ============================================================
   SITE NAV — match FR near-black, serif brand
============================================================ */
.site-nav {
  background: rgba(13, 12, 10, 0.94) !important;
  border-bottom: 1px solid var(--fr-line) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.nav-logo .logo-main {
  font-family: var(--fr-sans) !important;
  color: var(--fr-ash) !important;
  letter-spacing: 2.5px !important;
  font-weight: 700 !important;
}
.nav-logo .logo-main span { color: var(--fr-gold) !important; }
.nav-logo .logo-sub {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  letter-spacing: 2px !important;
}

.nav-links a,
.nav-mobile a {
  font-family: var(--fr-sans) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: var(--fr-text2) !important;
  border-radius: 2px !important;
  border-color: transparent !important;
  background: transparent !important;
}
.nav-links a:hover,
.nav-mobile a:hover {
  color: var(--fr-ash) !important;
  background: rgba(240, 236, 230, 0.04) !important;
}
.nav-links a.active {
  color: var(--fr-mark) !important;
  background: transparent !important;
  border-color: var(--fr-line-2) !important;
}

.btn-nav {
  font-family: var(--fr-sans) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  border-radius: 2px !important;
}
.btn-discord {
  background: rgba(143, 170, 191, 0.08) !important;
  border-color: rgba(143, 170, 191, 0.32) !important;
  color: var(--fr-mark-dim) !important;
}
.btn-discord:hover {
  background: rgba(143, 170, 191, 0.18) !important;
  border-color: var(--fr-mark) !important;
  color: var(--fr-mark) !important;
}
.btn-fab {
  background: rgba(200, 168, 74, 0.08) !important;
  border-color: rgba(200, 168, 74, 0.35) !important;
  color: var(--fr-gold) !important;
}
.btn-fab:hover {
  background: rgba(200, 168, 74, 0.18) !important;
  border-color: var(--fr-gold) !important;
  color: var(--fr-ash) !important;
}
.nav-hamburger { border-color: var(--fr-line-2) !important; background: transparent !important; }
.nav-hamburger span { background: var(--fr-mark-dim) !important; }

.nav-mobile {
  background: rgba(13, 12, 10, 0.98) !important;
  border-bottom: 1px solid var(--fr-line) !important;
}

/* ============================================================
   HOMEPAGE HERO — FR atmosphere + preserved HEROIMAGE.png
   The full HEROIMAGE sits on the right, then we fade to near-
   black on the left so the content stays fully legible.
============================================================ */
.hero {
  background:
    linear-gradient(90deg,
      var(--fr-near-black) 22%,
      rgba(13, 12, 10, 0.92) 48%,
      rgba(13, 12, 10, 0.55) 68%,
      rgba(13, 12, 10, 0.15) 88%,
      transparent 100%
    ),
    radial-gradient(ellipse 120% 80% at 50% 0%, rgba(74, 59, 46, 0.26) 0%, transparent 60%),
    url('../Images/Herobanner/HEROIMAGE.png') right center / auto 100% no-repeat,
    var(--fr-near-black) !important;
  min-height: 720px !important;
  padding: 80px 40px !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: left !important;
}
.hero-grid {
  background-image:
    linear-gradient(rgba(212, 224, 232, 0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212, 224, 232, 0.03) 1px, transparent 1px) !important;
  background-size: 60px 60px !important;
  -webkit-mask-image: linear-gradient(90deg, black 25%, transparent 65%) !important;
  mask-image: linear-gradient(90deg, black 25%, transparent 65%) !important;
  opacity: 0.7;
}
.hero-glow,
.hero-glow-purple { display: none !important; }

.hero-content {
  max-width: 720px !important;
  margin: 0 !important;
  text-align: left !important;
}
.hero-eyebrow {
  color: var(--fr-mark-dim) !important;
  font-family: var(--fr-sans) !important;
  letter-spacing: 0.22em !important;
  font-size: 10.5px !important;
  justify-content: flex-start !important;
}
.hero-eyebrow::before {
  background: var(--fr-mark-dim) !important;
  width: 30px !important;
  height: 1px !important;
  border-radius: 0 !important;
}
.hero-title {
  font-family: var(--fr-serif) !important;
  font-weight: 400 !important;
  color: var(--fr-ash) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  font-size: clamp(2.6rem, 6vw, 4.5rem) !important;
  line-height: 1.02 !important;
  margin-bottom: 0.35em !important;
}
.hero-title span { color: var(--fr-gold) !important; }
.hero-subtitle {
  color: var(--fr-mark) !important;
  font-family: var(--fr-sans) !important;
  font-weight: 300 !important;
  letter-spacing: 0.28em !important;
  font-size: 0.85rem !important;
  text-transform: uppercase !important;
  margin: 0.75em 0 1.5rem !important;
}
.hero-tagline {
  color: var(--fr-dead-stone) !important;
  font-family: var(--fr-serif) !important;
  font-style: italic !important;
  font-size: clamp(0.95rem, 1.6vw, 1.08rem) !important;
  line-height: 1.75 !important;
  max-width: 520px !important;
  margin: 0 0 2rem !important;
}
.hero-cta { justify-content: flex-start !important; }

/* On narrow viewports, drop the image and center the copy like
   a classic FR hero so nothing overlaps awkwardly. */
@media (max-width: 960px) {
  .hero {
    background:
      radial-gradient(ellipse 80% 60% at 50% 30%, rgba(26, 23, 20, 0) 0%, rgba(13, 12, 10, 0.92) 75%),
      radial-gradient(ellipse 120% 80% at 50% 0%, rgba(74, 59, 46, 0.26) 0%, transparent 60%),
      linear-gradient(180deg, #141210, var(--fr-near-black)) !important;
    justify-content: center !important;
    text-align: center !important;
    min-height: 620px !important;
  }
  .hero-content {
    margin: 0 auto !important;
    text-align: center !important;
  }
  .hero-eyebrow,
  .hero-cta { justify-content: center !important; }
  .hero-tagline { margin-left: auto !important; margin-right: auto !important; }
}

/* Decorative rule accents reused around the site */
.fr-rule-accent {
  width: 120px;
  height: 1px;
  margin: 1.5rem auto;
  background: linear-gradient(90deg, transparent, var(--fr-mark), transparent);
}

/* ============================================================
   BUTTONS — thin, outlined, wide-tracked
============================================================ */
.btn {
  font-family: var(--fr-sans) !important;
  font-weight: 600 !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  border-radius: 2px !important;
  padding: 12px 26px !important;
  transition: all .3s cubic-bezier(.16,1,.3,1) !important;
}
.btn svg { opacity: 0.75; }
.btn-lg { padding: 14px 32px !important; font-size: 0.78rem !important; }
.btn-sm { padding: 8px 18px !important; font-size: 0.68rem !important; }

.btn-primary {
  background: rgba(200, 168, 74, 0.12) !important;
  color: var(--fr-gold) !important;
  border: 1px solid rgba(200, 168, 74, 0.45) !important;
  box-shadow: none !important;
}
.btn-primary:hover {
  background: rgba(200, 168, 74, 0.22) !important;
  border-color: var(--fr-gold) !important;
  color: var(--fr-ash) !important;
  box-shadow: none !important;
}
.btn-outline {
  background: transparent !important;
  color: var(--fr-mark) !important;
  border: 1px solid var(--fr-line-2) !important;
}
.btn-outline:hover {
  background: rgba(212, 224, 232, 0.05) !important;
  border-color: var(--fr-mark) !important;
  color: var(--fr-ash) !important;
}
.btn-teal,
.btn-purple,
.btn-orange {
  background: transparent !important;
  border: 1px solid var(--fr-line-2) !important;
  color: var(--fr-mark) !important;
}
.btn-teal:hover,
.btn-purple:hover,
.btn-orange:hover {
  background: rgba(212, 224, 232, 0.06) !important;
  border-color: var(--fr-mark) !important;
  color: var(--fr-ash) !important;
  box-shadow: none !important;
}

/* ============================================================
   BREADCRUMB — small, sans, tracked
============================================================ */
.breadcrumb {
  background: transparent !important;
  border-bottom: 1px solid var(--fr-line) !important;
  font-family: var(--fr-sans) !important;
  font-size: 10.5px !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
}
.breadcrumb a { color: var(--fr-mark-dim) !important; }
.breadcrumb a:hover { color: var(--fr-ash) !important; }
.breadcrumb .sep { color: var(--fr-text2) !important; }
.breadcrumb .current { color: var(--fr-ash) !important; font-weight: 500; }

/* ============================================================
   STATS BAR
============================================================ */
.stats-bar {
  background: transparent !important;
  border-top: 1px solid var(--fr-line) !important;
  border-bottom: 1px solid var(--fr-line) !important;
}
.stat-item { border-right: 1px solid var(--fr-line) !important; }
.stat-num,
.stat-num.accent-teal,
.stat-num.accent-blue,
.stat-num.accent-purple,
.stat-num.accent-orange {
  font-family: var(--fr-serif) !important;
  font-weight: 400 !important;
  color: var(--fr-mark) !important;
  font-size: 2rem !important;
}
.stat-label {
  color: var(--fr-text2) !important;
  font-family: var(--fr-sans) !important;
  letter-spacing: 0.18em !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
}

/* ============================================================
   SECTION HEADINGS — eyebrow + serif title pattern
============================================================ */
.section-label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.8rem !important;
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  font-size: 10.5px !important;
  font-weight: 700 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
}
.section-label::before {
  content: '';
  display: inline-block;
  width: 28px;
  height: 1px;
  background: var(--fr-mark-dim);
}
.section-title {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.04em !important;
  font-size: clamp(1.8rem, 4vw, 2.6rem) !important;
  line-height: 1.2 !important;
}
.section-desc {
  font-family: var(--fr-serif) !important;
  font-style: italic !important;
  color: var(--fr-dead-stone) !important;
  font-size: 1rem !important;
  line-height: 1.85 !important;
  max-width: 620px !important;
}

/* ============================================================
   PRODUCT CARDS (index.html + docs.html)
============================================================ */
.product-card {
  background: #110f0c !important;
  border: 1px solid var(--fr-line) !important;
  border-top: 1px solid var(--fr-line) !important;
  border-radius: 2px !important;
  position: relative;
  box-shadow: none !important;
}
.product-card::after {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--fr-mark), transparent);
  opacity: 0;
  transition: opacity .4s ease;
  z-index: 2;
}
.product-card:hover {
  background: #13110e !important;
  border-color: var(--fr-line-2) !important;
  box-shadow: none !important;
}
.product-card:hover::after { opacity: 1; }
.card-image { background: #0a0908 !important; }
.card-img-placeholder {
  background: linear-gradient(135deg, #110f0c 0%, #0a0908 100%) !important;
  color: var(--fr-text2) !important;
}
.card-body { padding: 22px !important; gap: 12px !important; }
.card-studio {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  letter-spacing: 0.2em !important;
  font-size: 10px !important;
  font-weight: 700 !important;
}
.card-title {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.03em !important;
  font-size: 1.25rem !important;
  line-height: 1.2 !important;
}
.card-desc {
  font-family: var(--fr-serif) !important;
  color: var(--fr-dead-stone) !important;
  font-size: 0.9rem !important;
  line-height: 1.75 !important;
}
.detail-link {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  font-size: 10px !important;
  font-weight: 600 !important;
}
.detail-link:hover { color: var(--fr-mark) !important; }

.tag {
  background: rgba(240, 236, 230, 0.04) !important;
  border: 1px solid var(--fr-line) !important;
  color: var(--fr-mark-dim) !important;
  font-family: var(--fr-sans) !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  border-radius: 2px !important;
}

/* ============================================================
   BADGES — unified FR pill
============================================================ */
.badge {
  font-family: var(--fr-sans) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  border-radius: 2px !important;
  padding: 5px 10px !important;
  background: rgba(240, 236, 230, 0.04) !important;
  border: 1px solid var(--fr-line-2) !important;
  color: var(--fr-mark-dim) !important;
}
.badge-released { color: #9cd6b5 !important; border-color: rgba(156, 214, 181, 0.35) !important; background: rgba(156, 214, 181, 0.06) !important; }
.badge-indev,
.badge-testing { color: var(--fr-gold) !important; border-color: rgba(200, 168, 74, 0.35) !important; background: rgba(200, 168, 74, 0.06) !important; }
.badge-available { color: var(--fr-mark) !important; border-color: rgba(212, 224, 232, 0.3) !important; background: rgba(212, 224, 232, 0.04) !important; }
.badge-editor { color: var(--fr-gold) !important; border-color: rgba(200, 168, 74, 0.35) !important; background: rgba(200, 168, 74, 0.06) !important; }
.badge-on-hold { color: var(--fr-text2) !important; border-color: var(--fr-line-2) !important; background: transparent !important; }
.badge-beta { color: var(--fr-mark) !important; border-color: rgba(212, 224, 232, 0.28) !important; background: rgba(212, 224, 232, 0.04) !important; }
.badge-dot { background: currentColor !important; opacity: 0.85; }

/* ============================================================
   FEATURED SPOTLIGHT CARD (home)
============================================================ */
.featured-card,
.featured-card--fated {
  background: linear-gradient(135deg, #110f0c 0%, var(--fr-black) 100%) !important;
  border: 1px solid var(--fr-line) !important;
  border-top: 1px solid rgba(200, 168, 74, 0.4) !important;
  border-radius: 2px !important;
  box-shadow: none !important;
}
.featured-image, .featured-image--fated {
  background: #0a0908 !important;
}
.featured-label {
  font-family: var(--fr-sans) !important;
  color: var(--fr-gold) !important;
  letter-spacing: 0.22em !important;
  font-weight: 600 !important;
}
.featured-title {
  font-family: var(--fr-serif) !important;
  font-weight: 400 !important;
  color: var(--fr-ash) !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
}
.featured-desc {
  font-family: var(--fr-serif) !important;
  color: var(--fr-dead-stone) !important;
  font-style: italic;
}

.progress-bar { background: rgba(212, 224, 232, 0.08) !important; border-radius: 1px !important; }
.progress-fill { background: var(--fr-mark) !important; border-radius: 1px !important; }
.progress-label { font-family: var(--fr-sans) !important; color: var(--fr-text2) !important; letter-spacing: 0.12em !important; text-transform: uppercase; }

/* ============================================================
   DOCS HUB CARDS (docs.html)
============================================================ */
.doc-card {
  background: #110f0c !important;
  border: 1px solid var(--fr-line) !important;
  border-radius: 2px !important;
  box-shadow: none !important;
  position: relative;
}
.doc-card:hover {
  background: #13110e !important;
  border-color: var(--fr-line-2) !important;
  box-shadow: none !important;
}
.doc-card-accent { opacity: 0.7; }
.doc-card-studio {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  letter-spacing: 0.2em !important;
}
.doc-card-title {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.03em !important;
}
.doc-card-desc {
  font-family: var(--fr-serif) !important;
  color: var(--fr-dead-stone) !important;
  font-size: 0.9rem !important;
  line-height: 1.75 !important;
}
.doc-card-cta {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  font-size: 10px !important;
  font-weight: 600 !important;
}

/* ============================================================
   PRODUCT DETAIL HERO (products/*.html)
============================================================ */
.product-hero {
  background:
    radial-gradient(ellipse 80% 60% at 50% 30%, rgba(26, 23, 20, 0) 0%, rgba(13, 12, 10, 0.85) 78%),
    radial-gradient(ellipse 120% 80% at 50% 0%, rgba(74, 59, 46, 0.24) 0%, transparent 60%),
    linear-gradient(180deg, #141210, var(--fr-near-black)) !important;
  border-bottom: 1px solid var(--fr-line) !important;
  padding: clamp(56px, 8vw, 96px) 32px clamp(40px, 6vw, 72px) !important;
  text-align: center !important;
  position: relative;
  overflow: hidden;
}
.product-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(212, 224, 232, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212, 224, 232, 0.025) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
}
.product-hero-inner {
  position: relative;
  z-index: 1;
  text-align: center !important;
}
.product-hero-top {
  justify-content: center !important;
  align-items: center !important;
  flex-direction: column !important;
  gap: 14px !important;
}
.product-hero-studio {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  letter-spacing: 0.22em !important;
  font-size: 11px !important;
  font-weight: 700 !important;
}
.product-hero-title {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  font-size: clamp(2.2rem, 6vw, 4.2rem) !important;
  line-height: 1.05 !important;
}
.product-hero-tagline,
.product-hero-desc {
  font-family: var(--fr-serif) !important;
  font-style: italic !important;
  color: var(--fr-dead-stone) !important;
  max-width: 640px !important;
  margin: 1rem auto 0 !important;
  font-size: clamp(0.95rem, 1.8vw, 1.1rem) !important;
  line-height: 1.8 !important;
  text-align: center !important;
}

/* Optional hero rule separator that any product page can drop in */
.product-hero .hero-rule,
.fr-hero-rule {
  width: 120px;
  height: 1px;
  margin: 22px auto;
  background: linear-gradient(90deg, transparent, var(--fr-mark), transparent);
}
.product-hero-version {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  font-size: 10.5px !important;
}
.product-hero-meta {
  justify-content: center !important;
}

/* ============================================================
   PRODUCT DETAIL BODY — content sections
============================================================ */
.product-body {
  background: var(--fr-near-black) !important;
  padding: 64px 32px !important;
}
.product-layout {
  gap: 40px !important;
}

/* Content blocks (right-column and main-column panels) */
.content-block {
  background: #110f0c !important;
  border: 1px solid var(--fr-line) !important;
  border-radius: 2px !important;
  box-shadow: none !important;
}
.block-header {
  border-bottom: 1px solid var(--fr-line) !important;
  background: rgba(240, 236, 230, 0.02) !important;
}
.block-title {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark) !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase !important;
}
.block-icon {
  background: rgba(212, 224, 232, 0.06) !important;
  border: 1px solid var(--fr-line-2) !important;
  color: var(--fr-mark) !important;
  border-radius: 2px !important;
}

/* Feature lists (product pages) */
.feature-list .feature-item {
  background: #110f0c !important;
  border: 1px solid var(--fr-line) !important;
  border-radius: 2px !important;
}
.feature-list .feature-item:hover {
  border-color: var(--fr-mark-dim) !important;
  background: #13110e !important;
}
.feature-list .feature-icon {
  background: rgba(212, 224, 232, 0.06) !important;
  border: 1px solid var(--fr-line-2) !important;
  color: var(--fr-mark) !important;
}
.feature-list .feature-name {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.02em !important;
  font-size: 14px !important;
}
.feature-list .feature-desc {
  font-family: var(--fr-serif) !important;
  color: var(--fr-dead-stone) !important;
  font-size: 13px !important;
  line-height: 1.7 !important;
}

/* Screenshots */
.screenshot-section,
.screenshot-placeholder {
  background: #0a0908 !important;
  border: 1px solid var(--fr-line) !important;
  border-radius: 2px !important;
}

/* Module grid (dynamic rpg worlds) */
.module-card {
  background: #110f0c !important;
  border: 1px solid var(--fr-line) !important;
  border-left: 3px solid var(--fr-old-wood) !important;
  border-radius: 0 2px 2px 0 !important;
}
.module-name {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.02em !important;
}
.module-desc {
  font-family: var(--fr-serif) !important;
  color: var(--fr-dead-stone) !important;
}

/* Spec list sidebar */
.spec-row { border-bottom: 1px solid var(--fr-line) !important; }
.spec-key {
  font-family: var(--fr-sans) !important;
  color: var(--fr-text2) !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
}
.spec-val {
  font-family: var(--fr-sans) !important;
  color: var(--fr-ash) !important;
  letter-spacing: 0.06em !important;
  font-size: 11.5px !important;
}

/* CTA banner at end of product pages */
.cta-banner,
.product-cta {
  background: linear-gradient(135deg, #110f0c 0%, var(--fr-black) 100%) !important;
  border: 1px solid var(--fr-line) !important;
  border-top: 1px solid rgba(200, 168, 74, 0.4) !important;
  border-radius: 2px !important;
  box-shadow: none !important;
}
.cta-banner::after,
.product-cta::after { display: none !important; }
.cta-title,
.product-cta-text h3 {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  font-size: 1.5rem !important;
}
.cta-desc,
.product-cta-text p {
  font-family: var(--fr-serif) !important;
  color: var(--fr-dead-stone) !important;
  font-style: italic;
}

.detail-content {
  background: var(--fr-near-black) !important;
  color: var(--fr-text) !important;
}
.detail-section {
  border-bottom: 1px solid var(--fr-line) !important;
  padding: clamp(48px, 6vw, 72px) 32px !important;
}
.detail-section-title,
.detail-section h2 {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.04em !important;
  font-size: clamp(1.5rem, 3vw, 2rem) !important;
}
.detail-section h3 {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.03em !important;
}

/* Body copy on product detail pages */
.detail-content p,
.detail-body p {
  color: var(--fr-text) !important;
  font-family: var(--fr-serif) !important;
  line-height: 1.85;
}

/* Code blocks */
pre, code {
  font-family: 'Cascadia Code', 'Consolas', 'SF Mono', monospace !important;
}

/* ============================================================
   DOCUMENTATION PAGE-WIDE OVERRIDES (Documentations/*.html)
   --------------------------------------------------------
   Each plugin documentation file ships with its own inline
   stylesheet. The rules below reach in at identity level
   (palette + headings + links) without disturbing their
   sidebars, grids, code blocks, or tables.
============================================================ */
/* Re-tint the doc sidebar backdrop to FR stone */
.sidebar {
  background: #110f0c !important;
  border-right: 1px solid var(--fr-line) !important;
}
.sidebar .brand-name,
.brand-name {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.04em !important;
}
.sidebar .brand-meta,
.brand-meta {
  font-family: var(--fr-sans) !important;
  color: var(--fr-text2) !important;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 10.5px !important;
}
.sidebar .nav h4,
aside.sidebar .nav h4 {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  letter-spacing: 0.2em !important;
  text-transform: uppercase;
}
.sidebar .nav a,
aside.sidebar .nav a {
  font-family: var(--fr-sans) !important;
  color: var(--fr-text2) !important;
  font-size: 12.5px !important;
  letter-spacing: 0.08em;
}
.sidebar .nav a:hover,
aside.sidebar .nav a:hover {
  color: var(--fr-ash) !important;
  background: rgba(212, 224, 232, 0.04) !important;
}
.sidebar .nav a.active,
aside.sidebar .nav a.active {
  color: var(--fr-mark) !important;
  background: transparent !important;
  border-left-color: var(--fr-mark) !important;
}

/* Mobile topbar in docs */
.topbar {
  background: rgba(13, 12, 10, 0.96) !important;
  border-bottom: 1px solid var(--fr-line) !important;
}
.topbar-title {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase;
}
.menu-toggle {
  background: transparent !important;
  border: 1px solid var(--fr-line-2) !important;
  color: var(--fr-mark) !important;
}

/* Inline doc content */
.main h1,
.main h2,
.main h3,
.main h4,
main.main h1,
main.main h2,
main.main h3,
main.main h4 {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.03em !important;
}
.main h2, main.main h2 { border-bottom-color: var(--fr-line) !important; }
.main p, main.main p { color: var(--fr-text) !important; }
.main a, main.main a { color: var(--fr-mark) !important; border-bottom-color: transparent !important; }
.main a:hover, main.main a:hover { color: var(--fr-ash) !important; border-bottom-color: var(--fr-mark) !important; }
.main strong, main.main strong { color: var(--fr-ash) !important; }
.main em, main.main em { color: var(--fr-text); }

/* Tables inside doc pages */
.main table, main.main table { background: transparent !important; }
.main th, main.main th {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  background: rgba(240, 236, 230, 0.025) !important;
  border-bottom: 1px solid var(--fr-line) !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase;
}
.main td, main.main td { border-bottom: 1px solid var(--fr-line) !important; color: var(--fr-text) !important; }
.main .table-wrap, main.main .table-wrap { border: 1px solid var(--fr-line) !important; border-radius: 2px !important; }

/* Code & pre in docs */
.main code, main.main code, p code, li code, td code {
  background: rgba(240, 236, 230, 0.04) !important;
  border: 1px solid var(--fr-line) !important;
  color: var(--fr-ash) !important;
}
.main pre, main.main pre {
  background: #0a0908 !important;
  border: 1px solid var(--fr-line) !important;
  border-radius: 2px !important;
  color: var(--fr-text) !important;
}

/* Callouts, cards inside docs */
.main .card,
main.main .card,
.main .feature,
main.main .feature,
.main .callout,
main.main .callout,
.main .tldr,
main.main .tldr {
  background: #110f0c !important;
  border: 1px solid var(--fr-line) !important;
  border-radius: 2px !important;
  box-shadow: none !important;
}
.main .feature:hover,
main.main .feature:hover {
  background: #13110e !important;
  border-color: var(--fr-mark-dim) !important;
  transform: translateY(-2px);
}
.main .feature-title,
main.main .feature-title,
.main .callout-title,
main.main .callout-title,
.main .tldr-label,
main.main .tldr-label {
  font-family: var(--fr-sans) !important;
  letter-spacing: 0.16em !important;
  text-transform: uppercase !important;
  color: var(--fr-mark) !important;
}
.main .feature-desc,
main.main .feature-desc,
.main .feature-icon,
main.main .feature-icon {
  color: var(--fr-dead-stone) !important;
}
.main .feature-icon,
main.main .feature-icon {
  background: rgba(212, 224, 232, 0.06) !important;
  border: 1px solid var(--fr-line) !important;
}

/* Lede / hero paragraph on doc pages */
.main .lede, main.main .lede {
  font-family: var(--fr-serif) !important;
  font-style: italic !important;
  color: var(--fr-dead-stone) !important;
}

/* Step lists */
.main .steps li::before,
main.main .steps li::before {
  background: rgba(200, 168, 74, 0.22) !important;
  color: var(--fr-gold) !important;
  font-family: var(--fr-sans) !important;
  border: 1px solid rgba(200, 168, 74, 0.45) !important;
  box-shadow: none !important;
}
.main .steps li,
main.main .steps li { border-left-color: var(--fr-line) !important; }
.main .step-title, main.main .step-title {
  font-family: var(--fr-sans) !important;
  color: var(--fr-ash) !important;
  letter-spacing: 0.04em;
}

/* Doc-internal badges (inline <span class="badge">) */
.main .badge, main.main .badge,
.main .badge--accent, main.main .badge--accent {
  font-family: var(--fr-sans) !important;
  color: var(--fr-mark-dim) !important;
  background: rgba(240, 236, 230, 0.04) !important;
  border-color: var(--fr-line-2) !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase;
}
.main .badge--accent, main.main .badge--accent {
  color: var(--fr-gold) !important;
  border-color: rgba(200, 168, 74, 0.45) !important;
  background: rgba(200, 168, 74, 0.06) !important;
}

/* Arch / module diagrams */
.main .arch-diagram, main.main .arch-diagram {
  background: #0a0908 !important;
  border: 1px solid var(--fr-line) !important;
  color: var(--fr-dead-stone) !important;
}
.main .arch-diagram .hl, main.main .arch-diagram .hl { color: var(--fr-mark) !important; }

/* Hero area inside documentation */
.main .hero, main.main .hero {
  background: transparent !important;
  min-height: auto !important;
  padding: 0 !important;
  text-align: left !important;
  align-items: stretch !important;
  justify-content: flex-start !important;
}
.main .hero h1, main.main .hero h1 {
  font-family: var(--fr-serif) !important;
  color: var(--fr-ash) !important;
  font-weight: 400 !important;
  letter-spacing: 0.03em !important;
}

/* ============================================================
   FORMS (contact page, etc.)
============================================================ */
input,
textarea,
select,
button {
  font-family: var(--fr-sans);
}
input[type="text"], input[type="email"], input[type="url"],
textarea {
  background: #110f0c !important;
  color: var(--fr-text) !important;
  border: 1px solid var(--fr-line-2) !important;
  border-radius: 2px !important;
}
input[type="text"]:focus, input[type="email"]:focus, input[type="url"]:focus,
textarea:focus {
  outline: none !important;
  border-color: var(--fr-mark) !important;
  box-shadow: 0 0 0 1px rgba(212, 224, 232, 0.25) !important;
}

/* ============================================================
   FOOTER
============================================================ */
.site-footer,
footer.site-footer,
footer:not([role="banner"]) {
  background: var(--fr-black) !important;
  border-top: 1px solid var(--fr-line) !important;
  color: var(--fr-text2) !important;
  font-family: var(--fr-sans) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.08em !important;
}
.site-footer a,
footer:not([role="banner"]) a {
  color: var(--fr-mark-dim) !important;
}
.site-footer a:hover,
footer:not([role="banner"]) a:hover {
  color: var(--fr-ash) !important;
}

/* ============================================================
   REUSABLE FR DISPLAY BLOCKS (drop-in hero & labels)
============================================================ */
.fr-doc-hero {
  position: relative;
  padding: clamp(48px, 8vw, 96px) 24px clamp(40px, 6vw, 72px);
  overflow: hidden;
  background:
    radial-gradient(ellipse 80% 60% at 50% 30%, rgba(26, 23, 20, 0) 0%, rgba(13, 12, 10, 0.85) 78%),
    radial-gradient(ellipse 120% 80% at 50% 0%, rgba(74, 59, 46, 0.22) 0%, transparent 60%),
    linear-gradient(180deg, #141210, var(--fr-near-black));
  border-bottom: 1px solid var(--fr-line);
  text-align: center;
}
.fr-doc-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(212, 224, 232, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212, 224, 232, 0.025) 1px, transparent 1px);
  background-size: 60px 60px;
  pointer-events: none;
  z-index: 0;
}
.fr-doc-hero > * { position: relative; z-index: 1; }

.fr-doc-hero .fr-mark {
  display: inline-block;
  width: 56px;
  height: 56px;
  margin-bottom: 18px;
  opacity: 0.75;
  animation: frMarkPulse 4s ease-in-out infinite;
}
.fr-doc-hero .fr-mark svg { width: 100%; height: 100%; }
.fr-doc-hero .fr-mark svg line,
.fr-doc-hero .fr-mark svg circle {
  stroke: var(--fr-mark);
  fill: none;
  stroke-width: 1.25;
}

.fr-doc-hero .fr-eyebrow {
  display: inline-block;
  font-family: var(--fr-sans);
  font-size: 10.5px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--fr-mark-dim);
  margin-bottom: 14px;
}

.fr-doc-hero h1,
.fr-doc-hero .fr-title {
  font-family: var(--fr-serif);
  font-weight: 400;
  font-size: clamp(2.2rem, 6vw, 4.2rem);
  letter-spacing: 0.06em;
  line-height: 1.05;
  text-transform: uppercase;
  color: var(--fr-ash);
  margin: 0 0 14px;
}
.fr-doc-hero h1 em,
.fr-doc-hero .fr-title em {
  display: block;
  font-style: normal;
  font-size: 0.42em;
  letter-spacing: 0.3em;
  color: var(--fr-mark);
  margin-top: 0.45em;
  font-family: var(--fr-sans);
  font-weight: 400;
}

.fr-doc-hero .fr-rule {
  width: 120px;
  height: 1px;
  margin: 20px auto;
  background: linear-gradient(90deg, transparent, var(--fr-mark), transparent);
}

.fr-doc-hero .fr-sub,
.fr-doc-hero .fr-lede {
  font-family: var(--fr-serif);
  font-style: italic;
  font-size: clamp(0.95rem, 1.8vw, 1.08rem);
  line-height: 1.75;
  max-width: 640px;
  margin: 0 auto 16px;
  color: var(--fr-dead-stone);
}

.fr-doc-hero .fr-pills {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-top: 14px;
}
.fr-doc-hero .fr-pill {
  font-family: var(--fr-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 5px 12px;
  border: 1px solid var(--fr-line-2);
  border-radius: 999px;
  color: var(--fr-mark-dim);
  background: rgba(240, 236, 230, 0.02);
}
.fr-doc-hero .fr-pill.gold { color: var(--fr-gold); border-color: rgba(200, 168, 74, 0.38); }
.fr-doc-hero .fr-pill.ok { color: #9cd6b5; border-color: rgba(156, 214, 181, 0.38); }

@keyframes frMarkPulse {
  0%, 100% { opacity: 0.55; filter: drop-shadow(0 0 6px rgba(212, 224, 232, 0.30)); }
  50%      { opacity: 0.90; filter: drop-shadow(0 0 18px rgba(212, 224, 232, 0.60)); }
}

/* Small shared label */
.fr-label {
  display: inline-flex;
  align-items: center;
  gap: 0.8rem;
  font-family: var(--fr-sans);
  font-size: 10.5px;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--fr-mark-dim);
  margin-bottom: 14px;
}
.fr-label::before {
  content: '';
  display: inline-block;
  width: 24px;
  height: 1px;
  background: var(--fr-mark-dim);
}

.fr-divider {
  border: 0;
  border-top: 1px solid var(--fr-line);
  margin: 48px 0;
}

/* ============================================================
   HOMEPAGE — tertiary hero link (Fated Realm, etc.)
============================================================ */
.hero-tertiary-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 18px;
  padding: 4px 0;
  color: var(--fr-mark-dim) !important;
  font-family: var(--fr-sans) !important;
  font-size: 12.5px !important;
  letter-spacing: 0.08em !important;
  text-transform: none !important;
  text-decoration: none !important;
  border-bottom: 1px solid transparent;
  transition: color 0.15s ease, border-color 0.15s ease;
}
.hero-tertiary-link em {
  color: var(--fr-gold) !important;
  font-style: italic;
  font-family: var(--fr-serif);
  letter-spacing: 0.04em;
}
.hero-tertiary-link:hover {
  color: var(--fr-ash) !important;
  border-bottom-color: var(--fr-line-2);
}

/* ============================================================
   HOMEPAGE — trust chips (promise row under stats-bar)
============================================================ */
.trust-chips {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px 14px;
  padding: 18px 24px 28px;
  max-width: 1100px;
  margin: 0 auto;
  border-bottom: 1px solid var(--fr-line);
}
.trust-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 5px 12px;
  font-family: var(--fr-sans);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--fr-mark-dim);
  background: rgba(240, 236, 230, 0.02);
  border: 1px solid var(--fr-line-2);
  border-radius: 999px;
  white-space: nowrap;
}
.trust-chip svg {
  color: var(--fr-gold);
  flex-shrink: 0;
}

/* ============================================================
   HOMEPAGE — product tiers (released / beta / indev / reference)
============================================================ */
.products-tier {
  margin: 0 0 40px;
}
.products-tier:last-child { margin-bottom: 0; }

.products-tier-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin: 0 0 18px;
  padding: 12px 0 10px;
  border-bottom: 1px solid var(--fr-line);
}

.tier-label {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--fr-sans);
  font-size: 12.5px;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--fr-ash);
}
.tier-dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--fr-mark-dim);
  box-shadow: 0 0 8px rgba(212, 224, 232, 0.4);
  flex-shrink: 0;
}
.tier-label--released .tier-dot { background: #3dba8f; box-shadow: 0 0 10px rgba(61, 186, 143, 0.6); }
.tier-label--beta     .tier-dot { background: #8be9fd; box-shadow: 0 0 10px rgba(139, 233, 253, 0.6); }
.tier-label--indev    .tier-dot { background: var(--fr-gold); box-shadow: 0 0 10px rgba(200, 168, 74, 0.6); }
.tier-label--ref      .tier-dot { background: #6878a0; box-shadow: none; }

.tier-label--released { color: #a7e6cd; }
.tier-label--beta     { color: #b8eef8; }
.tier-label--indev    { color: var(--fr-gold); }
.tier-label--ref      { color: var(--fr-text2); }

.tier-count {
  font-family: var(--fr-sans);
  font-size: 11.5px;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--fr-mark-dim);
}

/* Dimmed reference tier (on-hold / editor-only items) */
.products-tier--muted .products-grid { opacity: 0.78; }
.products-tier--muted .products-grid:hover { opacity: 1; transition: opacity 0.25s ease; }

@media (max-width: 640px) {
  .products-tier-header { flex-direction: column; align-items: flex-start; }
  .tier-count { font-size: 10.5px; }
  .trust-chips { gap: 8px; padding: 14px 16px 22px; }
  .trust-chip { font-size: 10px; padding: 4px 10px; }
}

/* ============================================================
   REDUCED MOTION
============================================================ */
@media (prefers-reduced-motion: reduce) {
  body::before, body::after { animation: none !important; }
  .fr-doc-hero .fr-mark { animation: none; }
}

/* ============================================================
   PRINT — strip ambient FX
============================================================ */
@media print {
  body::before, body::after { display: none !important; }
  body { background: #fff !important; color: #000 !important; }
  .site-nav, .nav-mobile, .sidebar, .topbar, .sidebar-backdrop { display: none !important; }
}
