/* ===============================
   THE REAPERS — Global Styles
   Uses local SOA font you added:
   /fonts/CarnivaleeFreakshow.ttf
   =============================== */

  @font-face {
  font-family: 'SOA';
  src: url('../fonts/CarnevaleeFreakshow.ttf') format('truetype');
  font-display: swap;
}

.site-title, .fx-title, h1, h2 {
  font-family: 'SOA', serif !important;
}



:root{
  --bg: #0e0e0f;
  --panel: #161718;
  --panel-alt: #141516;
  --text: #cfcfcf;
  --muted: #8b8f92;
  --gunmetal: #2C3539;     /* your gunmetal gray */
  --accent: #b01520;       /* dark blood red accent */
  --border: #212426;
  --shadow: 0 12px 30px rgba(0,0,0,.55);
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  line-height: 1.5;
}

img { max-width: 100%; height: auto; display: block; }

.wrap {
  width: min(1100px, 92vw);
  margin: 0 auto;
}

.site-header {
  background:
    radial-gradient(1200px 300px at 50% -100px, rgba(44,53,57,.35), transparent),
    #000;
  border-bottom: 3px solid var(--gunmetal);
  padding: 36px 0 18px;
  text-align: center;
}

.site-title {
  font-family: 'SOA', serif;
  font-size: clamp(40px, 6vw, 72px);
  letter-spacing: 2px;
  margin: 0 0 6px;
  color: #e6e6e6;
  text-shadow: 0 2px 0 #000;
}

.tagline {
  margin: 0 0 14px;
  color: var(--muted);
}

.nav {
  display: inline-flex;
  gap: 18px;
  flex-wrap: wrap;
}

.nav a {
  color: #d2d2d2;
  text-decoration: none;
  font-weight: 700;
  padding: 8px 10px;
  border: 1px solid transparent;
  border-radius: 6px;
  transition: .2s ease;
}

.nav a:hover {
  color: #fff;
  border-color: var(--gunmetal);
  background: #101214;
}

.panel {
  background: var(--panel);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  padding: 42px 0;
}

.panel.alt {
  background: var(--panel-alt);
}

.fx-title {
  font-family: 'SOA', serif;
  font-size: clamp(28px, 4.5vw, 48px);
  letter-spacing: 1px;
  margin: 0 0 12px;
  color: #e9e9e9;
}

.fx-title span {
  color: var(--gunmetal);
}

.lead {
  color: var(--muted);
  margin: 0 0 28px;
}

.grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 18px;
  align-items: stretch;
  margin-bottom: 28px;
}

.card {
  grid-column: span 6;
  background: #111213;
  border: 2px solid var(--gunmetal);
  border-radius: 10px;
  padding: 16px;
  box-shadow: var(--shadow);
  text-align: center;
}

.card.narrow { grid-column: span 3; }
.card.tiny   { grid-column: span 3; }

.card figcaption {
  margin-top: 10px;
  color: var(--muted);
  font-size: 0.95rem;
}

@media (max-width: 900px) {
  .card { grid-column: span 12; }
  .card.narrow, .card.tiny { grid-column: span 6; }
}

.ranks {
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 18px;
  background: #101112;
}

.ranks h3 {
  margin: 0 0 10px;
  font-family: 'SOA', serif;
  letter-spacing: .5px;
}

.ranks ul {
  list-style: none;
  padding: 0;
  margin: 0;
  columns: 1;
}

.ranks li {
  padding: 6px 0;
  border-bottom: 1px dashed #242628;
}
.ranks li:last-child { border-bottom: none; }

.code-list {
  width: min(740px, 94%);
  margin: 0 auto;
  padding: 0 12px;
  background: #101112;
  border: 2px solid var(--gunmetal);
  border-radius: 10px;
  box-shadow: var(--shadow);
}

.code-list li {
  padding: 10px 10px 10px 4px;
  border-bottom: 1px dashed #26292b;
}
.code-list li:last-child { border-bottom: none; }

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 14px;
  margin-top: 8px;
}

.site-footer {
  text-align: center;
  padding: 30px 0 40px;
  color: var(--muted);
  background: #0b0c0d;
  border-top: 2px solid var(--gunmetal);
}


/* make SOA easy to apply anywhere */
.soa { font-family: 'SOA', serif !important; letter-spacing: 1px; }

/* force it on all headings & key UI */
.site-title,
.fx-title,
h1, h2, h3,
nav a,
.ranks h3,
.card figcaption {
  font-family: 'SOA', serif !important;
  letter-spacing: 0.5px;
  text-transform: none; /* or uppercase if you prefer */
}

/* specific lines you showed (e.g., "Sons of the Reaper ★ SORCO") */
#sons .fx-title span,
#daughters .fx-title span {
  font-family: 'SOA', serif !important; /* makes the SORCO/DORCO span use SOA too */
}

/* optional: improve rendering on Windows */
html { -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; }


/* ---------- HERO LANDING ---------- */
.hero{
  position: relative;
  min-height: 70vh;
  display: grid;
  place-items: center;
  text-align: center;
  color: #e9e9e9;
  background: #0b0c0d url('../Images/hero.png') center/cover no-repeat fixed;
  border-bottom: 3px solid var(--gunmetal);
}
.hero__overlay{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.65) 0%, rgba(0,0,0,.55) 40%, rgba(0,0,0,.8) 100%);
  pointer-events:none;
}
.hero__inner{ position: relative; z-index: 1; padding: 72px 0; }

.site-title{ font-family:'SOA', serif; font-size: clamp(44px, 7vw, 92px); margin:0 0 8px; }
.tagline{ color:#cfcfcf; margin:0 0 20px; }

.cta-row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; margin: 6px 0 12px; }
.btn{
  display:inline-block; padding:12px 22px; border-radius:10px;
  font-weight:800; letter-spacing:.5px; text-decoration:none; transition:.2s ease;
  border:2px solid var(--gunmetal);
}
.btn--primary{ background: var(--gunmetal); color:#fff; }
.btn--primary:hover{ filter:brightness(1.15); }
.btn--ghost{ background: transparent; color:#e9e9e9; }
.btn--ghost:hover{ background:#121416; }

.hero-nav{ margin-top:10px; color:#9aa0a3; }
.hero-nav a{ color:#cfd3d5; text-decoration:none; font-weight:700; }
.hero-nav a:hover{ color:#fff; }

/* ---------- LANDING CARDS ---------- */
.landing-cards .grid{ gap:18px; }
.link-card{
  grid-column: span 4;
  background:#111213; border:2px solid var(--gunmetal); border-radius:12px;
  box-shadow: var(--shadow); text-align:center; padding:16px; color:#cfcfcf;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.link-card:hover{ transform: translateY(-3px); border-color:#3a454a; box-shadow: 0 16px 36px rgba(0,0,0,.55); }
.link-card img{ max-width: 260px; margin: 8px auto 10px; }
.link-card h3{ margin:6px 0 6px; font-size:1.3rem; }
.link-card p{ margin:0; color:#9aa0a3; }

@media (max-width: 900px){
  .link-card{ grid-column: span 12; }
}

/* ensure SOA class is available site-wide */
.soa{ font-family: 'SOA', serif !important; letter-spacing: .8px; }


.join-options {
  margin: 40px 0;
  padding: 20px;
  border: 2px solid var(--gunmetal);
  border-radius: 12px;
  background: rgba(0,0,0,0.4);
  text-align: center;
}

.join-options h3 {
  font-family: 'SOA', serif;
  font-size: 28px;
  margin-bottom: 10px;
}

.join-options .btn {
  margin-top: 12px;
}
