/*
Theme Name:   NBTI Media Ministries
Theme URI:    https://nothingbuttoinspire.com
Description:  A content-first editorial theme for NBTI Media Ministries — built for Scripture teaching, sermons, apologetics, podcasts, and daily articles. Brand identity: Ink Indigo, Lamp Gold, Parchment. Built on the Cornerstone mark. Standalone theme (no page builder required).
Author:       NBTI Media Ministries
Author URI:   https://nothingbuttoinspire.com
Version:      1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License:      GNU General Public License v2 or later
License URI:  http://www.gnu.org/licenses/gpl-2.0.html
Text Domain:  nbti
Tags:         blog, news, education, two-columns, right-sidebar, custom-logo, custom-menu, featured-images, full-width-template, sticky-post, theme-options, translation-ready
*/

/* ======================================================
   1. BRAND TOKENS
   ====================================================== */
:root {
  --ink:      #161D33;
  --deep:     #0C1124;
  --navy:     #2A3251;
  --gold:     #C79A3E;
  --gold-lt:  #E4BE6A;
  --oxblood:  #7A2E37;
  --parch:    #F3EDDF;
  --parch-2:  #FBF8F0;
  --stone:    #586173;
  --muted:    #8A93A8;
  --border:   #E6DFCD;
  --white:    #FFFFFF;

  --serif: 'Newsreader', Georgia, 'Times New Roman', serif;
  --sans:  'Hanken Grotesk', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;

  --wrap: 1280px;
  --gap:  64px;
}

/* ======================================================
   2. RESET & BASE
   ====================================================== */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--sans);
  font-size: 16px;
  line-height: 1.6;
  color: var(--ink);
  background: var(--parch);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--gold); text-decoration: none; transition: color .18s ease; }
a:hover { color: var(--oxblood); }
h1,h2,h3,h4,h5,h6 { font-family: var(--serif); font-weight: 500; line-height: 1.15; margin: 0; color: var(--ink); letter-spacing: -0.01em; }
p { margin: 0 0 1em; }
::selection { background: var(--gold-lt); color: var(--ink); }

/* Accessibility */
.screen-reader-text {
  position: absolute !important; clip: rect(1px,1px,1px,1px);
  width: 1px; height: 1px; overflow: hidden; padding: 0; border: 0;
}
.skip-link {
  position: absolute; left: -9999px; top: 0; z-index: 999;
  background: var(--gold); color: var(--ink); padding: 12px 20px;
  font-weight: 700; font-size: 13px;
}
.skip-link:focus { left: 12px; top: 12px; }

/* Containers */
.nbti-wrap { max-width: var(--wrap); margin: 0 auto; padding-left: 80px; padding-right: 80px; }

/* ======================================================
   3. ANNOUNCEMENT BANNER (full width)
   ====================================================== */
.nbti-announce { width: 100%; background: var(--oxblood); }
.nbti-announce__inner {
  display: flex; align-items: center; justify-content: center; gap: 12px;
  padding: 11px 80px; flex-wrap: wrap;
}
.nbti-announce span { font-size: 13px; font-weight: 600; color: var(--parch); }
.nbti-announce a {
  font-size: 13px; font-weight: 700; color: var(--gold-lt);
  display: inline-flex; align-items: center; gap: 4px;
}
.nbti-announce a:hover { color: var(--white); }

/* ======================================================
   4. HEADER / NAV (full width, sticky)
   ====================================================== */
.nbti-nav {
  width: 100%; background: var(--ink);
  border-bottom: 1px solid var(--navy);
  position: sticky; top: 0; z-index: 100;
}
.nbti-nav__inner {
  max-width: var(--wrap); margin: 0 auto; height: 64px;
  padding: 0 80px; display: flex; align-items: center; justify-content: space-between;
}
.nbti-nav__brand { flex: 0 0 auto; }
.nbti-logo { display: inline-flex; align-items: center; gap: 11px; }
.nbti-logo svg { width: 32px; height: 32px; display: block; flex: 0 0 auto; }
.nbti-logo__text {
  font-family: var(--serif); font-size: 18px; font-weight: 500;
  color: var(--parch); white-space: nowrap;
}
.nbti-nav .custom-logo-link { display: inline-flex; align-items: center; }
.nbti-nav .custom-logo { max-height: 44px; width: auto; }

/* Primary menu */
.nbti-menu { list-style: none; margin: 0; padding: 0; display: flex; align-items: center; }
.nbti-menu > li { position: relative; }
.nbti-menu > li > a {
  font-size: 14px; font-weight: 600; color: var(--muted);
  padding: 0 18px; height: 64px; display: flex; align-items: center;
  border-bottom: 2px solid transparent;
}
.nbti-menu > li > a:hover,
.nbti-menu > li.current-menu-item > a,
.nbti-menu > li.current_page_item > a {
  color: var(--parch); border-bottom-color: var(--gold);
}
.nbti-menu .sub-menu {
  list-style: none; margin: 0; padding: 8px 0; position: absolute; top: 100%; left: 0;
  min-width: 220px; background: var(--ink); border-top: 2px solid var(--gold);
  box-shadow: 0 12px 32px rgba(0,0,0,.32); opacity: 0; visibility: hidden;
  transform: translateY(6px); transition: all .18s ease; z-index: 50;
}
.nbti-menu > li:hover > .sub-menu { opacity: 1; visibility: visible; transform: translateY(0); }
.nbti-menu .sub-menu a {
  display: block; padding: 10px 20px; font-size: 13px; font-weight: 600;
  color: var(--muted); border-bottom: 1px solid var(--navy);
}
.nbti-menu .sub-menu li:last-child a { border-bottom: 0; }
.nbti-menu .sub-menu a:hover { color: var(--gold); background: var(--navy); }

.nbti-nav__cta { display: flex; align-items: center; gap: 16px; flex: 0 0 auto; }

/* Buttons */
.nbti-btn {
  display: inline-flex; align-items: center; gap: 8px; cursor: pointer;
  font-family: var(--sans); font-size: 13px; font-weight: 700;
  letter-spacing: 1.2px; text-transform: uppercase;
  padding: 10px 20px; border-radius: 2px; border: 1.5px solid transparent;
  transition: all .18s ease;
}
.nbti-btn--gold { background: var(--gold); color: var(--ink); border-color: var(--gold); }
.nbti-btn--gold:hover { background: var(--gold-lt); border-color: var(--gold-lt); color: var(--ink); box-shadow: 0 4px 16px rgba(199,154,62,.3); }
.nbti-btn--ghost { background: transparent; color: var(--ink); border-color: var(--ink); }
.nbti-btn--ghost:hover { background: var(--ink); color: var(--parch); }
.nbti-btn--ghost-light { background: transparent; color: var(--muted); border-color: var(--navy); }
.nbti-btn--ghost-light:hover { border-color: var(--gold); color: var(--gold); }

/* Mobile toggle */
.nbti-nav__toggle {
  display: none; flex-direction: column; gap: 4px; width: 38px; height: 38px;
  background: transparent; border: 1px solid var(--navy); border-radius: 3px;
  align-items: center; justify-content: center; cursor: pointer;
}
.nbti-nav__toggle span { width: 18px; height: 2px; background: var(--parch); display: block; transition: .2s; }

/* ======================================================
   5. TYPE BADGES (category tags)
   ====================================================== */
.nbti-badge {
  display: inline-block; font-family: var(--sans); font-size: 9px; font-weight: 700;
  letter-spacing: 1.8px; text-transform: uppercase; padding: 3px 8px; border-radius: 2px;
  background: var(--navy); color: var(--parch); white-space: nowrap;
}
.nbti-badge--teaching,
.nbti-badge--sermons,
.nbti-badge--sermon     { background: var(--gold);    color: var(--ink); }
.nbti-badge--bible-study,
.nbti-badge--study      { background: var(--navy);    color: var(--parch); }
.nbti-badge--apologetics,
.nbti-badge--defending-the-faith { background: var(--oxblood); color: var(--parch); }
.nbti-badge--got-questions,
.nbti-badge--questions  { background: var(--gold-lt); color: var(--ink); }
.nbti-badge--daily-walk,
.nbti-badge--podcast,
.nbti-badge--blog       { background: var(--stone);   color: var(--parch); }

/* ======================================================
   6. FEATURED HERO
   ====================================================== */
.nbti-hero { width: 100%; background: var(--ink); }
.nbti-hero__inner {
  max-width: var(--wrap); margin: 0 auto; padding: 0 80px;
  display: grid; grid-template-columns: 1fr 400px; min-height: 460px;
}
.nbti-hero__feature {
  padding: 56px 64px 48px 0; border-right: 1px solid var(--navy);
  display: flex; flex-direction: column; justify-content: space-between; gap: 28px;
}
.nbti-hero__tags { display: flex; align-items: center; gap: 10px; margin-bottom: 18px; }
.nbti-hero__kicker { font-size: 12px; font-weight: 600; color: var(--stone); }
.nbti-hero__title { font-size: 50px; line-height: 1.06; color: var(--parch); letter-spacing: -.5px; }
.nbti-hero__title a { color: inherit; }
.nbti-hero__title a:hover { color: var(--gold-lt); }
.nbti-hero__excerpt {
  font-family: var(--serif); font-style: italic; font-size: 19px; line-height: 1.55;
  color: var(--muted); max-width: 540px; margin: 18px 0 0;
}
.nbti-hero__foot { display: flex; align-items: center; justify-content: space-between; }
.nbti-hero__more {
  font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase;
  color: var(--gold-lt); display: inline-flex; align-items: center; gap: 6px;
}
.nbti-hero__more:hover { color: var(--white); }

.nbti-hero__recent { padding: 32px 0 32px 48px; }
.nbti-rail__head {
  display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px;
}
.nbti-rail__head span { font-size: 11px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold); }
.nbti-rail__head a { font-size: 12px; font-weight: 700; color: var(--stone); }
.nbti-rail__head a:hover { color: var(--gold-lt); }
.nbti-rail__item {
  display: flex; flex-direction: column; gap: 5px; padding: 15px 0;
  border-top: 1px solid var(--navy);
}
.nbti-rail__tags { display: flex; align-items: center; gap: 8px; }
.nbti-rail__date { font-size: 11px; color: var(--stone); }
.nbti-rail__title { font-family: var(--serif); font-size: 16px; font-weight: 500; line-height: 1.25; color: var(--parch); }
.nbti-rail__item:hover .nbti-rail__title { color: var(--gold-lt); }

/* ======================================================
   7. FEATURES STRIP
   ====================================================== */
.nbti-features { width: 100%; background: var(--deep); border-top: 1px solid var(--ink); border-bottom: 1px solid var(--ink); }
.nbti-features__inner { max-width: var(--wrap); margin: 0 auto; padding: 0 80px; display: grid; grid-template-columns: repeat(4, 1fr); }
.nbti-feature {
  padding: 22px 28px 24px; border-right: 1px solid var(--ink);
  display: flex; flex-direction: column; gap: 4px;
}
.nbti-feature:last-child { border-right: 0; }
.nbti-feature__label { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); }
.nbti-feature__title { font-family: var(--serif); font-size: 18px; font-weight: 500; color: var(--parch); line-height: 1.2; }
.nbti-feature__desc { font-size: 12px; line-height: 1.4; color: var(--stone); margin-top: 2px; }
.nbti-feature:hover .nbti-feature__title { color: var(--gold-lt); }

/* ======================================================
   8. MAIN LAYOUT (feed + sidebar)
   ====================================================== */
.nbti-main {
  max-width: var(--wrap); margin: 0 auto; padding: 0 80px;
  display: grid; grid-template-columns: 1fr 360px; gap: var(--gap); align-items: start;
}
.nbti-main--full { grid-template-columns: 1fr; }

.nbti-section__head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 16px; margin-bottom: 4px; border-bottom: 2px solid var(--ink);
}
.nbti-section__head h2, .nbti-section__head .h2 {
  font-family: var(--sans); font-size: 13px; font-weight: 700;
  letter-spacing: 3px; text-transform: uppercase; color: var(--ink);
}
.nbti-section__head a { font-size: 13px; font-weight: 700; color: var(--gold); display: inline-flex; align-items: center; gap: 4px; }
.nbti-section__head a:hover { color: var(--oxblood); }
.nbti-section { padding-top: 52px; }
.nbti-section + .nbti-section { padding-top: 40px; margin-top: 40px; border-top: 2px solid var(--ink); }

/* Feed item */
.nbti-feed__item {
  display: grid; grid-template-columns: 1fr 120px; gap: 24px;
  padding: 26px 0; border-bottom: 1px solid var(--border); align-items: start;
}
.nbti-feed__body { display: flex; flex-direction: column; gap: 9px; }
.nbti-feed__tags { display: flex; align-items: center; gap: 10px; }
.nbti-feed__date { font-size: 12px; color: var(--muted); }
.nbti-feed__title { font-size: 24px; line-height: 1.2; }
.nbti-feed__title a { color: var(--ink); }
.nbti-feed__title a:hover { color: var(--oxblood); }
.nbti-feed__excerpt { font-size: 14px; line-height: 1.6; color: var(--stone); margin: 0; }
.nbti-feed__thumb {
  height: 88px; border-radius: 2px; overflow: hidden; flex: 0 0 auto;
  background: var(--ink); display: flex; align-items: center; justify-content: center;
}
.nbti-feed__thumb img { width: 100%; height: 100%; object-fit: cover; }
.nbti-feed__thumb svg { width: 40px; height: 40px; opacity: .22; }

/* Load more */
.nbti-loadmore { padding: 28px 0; }

/* Sermons row */
.nbti-cards3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 24px; }
.nbti-vidcard { display: flex; flex-direction: column; gap: 10px; }
.nbti-vidcard__thumb {
  height: 116px; border-radius: 2px; position: relative; overflow: hidden;
  background: var(--ink); display: flex; align-items: center; justify-content: center;
}
.nbti-vidcard__thumb img { width: 100%; height: 100%; object-fit: cover; }
.nbti-vidcard__play {
  width: 36px; height: 36px; border-radius: 50%; background: rgba(228,190,106,.92);
  display: flex; align-items: center; justify-content: center; color: var(--ink);
  font-size: 12px; position: relative; z-index: 2;
}
.nbti-vidcard__series {
  position: absolute; bottom: 8px; left: 10px; z-index: 2;
  font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold-lt);
}
.nbti-vidcard__title { font-family: var(--serif); font-size: 16px; font-weight: 500; line-height: 1.25; }
.nbti-vidcard__title a { color: var(--ink); }
.nbti-vidcard__title a:hover { color: var(--oxblood); }
.nbti-vidcard__date { font-size: 12px; color: var(--muted); }

/* Numbered list (apologetics) */
.nbti-numlist__item {
  display: flex; gap: 20px; align-items: flex-start;
  padding: 18px 0; border-bottom: 1px solid var(--border);
}
.nbti-numlist__n { font-family: var(--serif); font-size: 11px; font-weight: 600; color: var(--oxblood); min-width: 28px; margin-top: 3px; }
.nbti-numlist__title { font-family: var(--serif); font-size: 19px; font-weight: 500; line-height: 1.2; }
.nbti-numlist__title a { color: var(--ink); }
.nbti-numlist__title a:hover { color: var(--oxblood); }
.nbti-numlist__excerpt { font-size: 13px; line-height: 1.5; color: var(--stone); margin: 4px 0 0; }

/* ======================================================
   9. SIDEBAR / WIDGETS
   ====================================================== */
.nbti-sidebar { padding-top: 52px; display: flex; flex-direction: column; gap: 40px; }
.nbti-widget { display: flex; flex-direction: column; }
.nbti-widget + .nbti-widget { border-top: 2px solid var(--ink); padding-top: 24px; }
.nbti-widget-title {
  font-family: var(--sans); font-size: 11px; font-weight: 700; letter-spacing: 2.5px;
  text-transform: uppercase; color: var(--ink); margin: 0 0 16px;
}
.nbti-widget ul { list-style: none; margin: 0; padding: 0; }
.nbti-widget li { padding: 12px 0; border-bottom: 1px solid var(--border); }
.nbti-widget li a { font-family: var(--serif); font-size: 16px; font-weight: 500; color: var(--ink); line-height: 1.25; }
.nbti-widget li a:hover { color: var(--oxblood); }

/* Daily Word signup card */
.nbti-dailyword {
  background: var(--ink); border-radius: 3px; padding: 32px;
  display: flex; flex-direction: column; gap: 14px;
}
.nbti-dailyword__eyebrow { font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold); }
.nbti-dailyword__title { font-size: 22px; color: var(--parch); line-height: 1.2; }
.nbti-dailyword__text { font-size: 13px; line-height: 1.55; color: var(--muted); margin: 0; }
.nbti-dailyword__toggle { display: flex; gap: 8px; }
.nbti-dailyword__toggle button {
  flex: 1; padding: 10px; font-family: var(--sans); font-size: 12px; font-weight: 700;
  border: none; border-radius: 2px; cursor: pointer;
}
.nbti-dailyword__toggle button[aria-pressed="true"] { background: var(--gold); color: var(--ink); }
.nbti-dailyword__toggle button[aria-pressed="false"] { background: var(--navy); color: var(--muted); }
.nbti-dailyword input[type="email"] {
  padding: 12px 14px; font-family: var(--sans); font-size: 14px;
  border: 1px solid var(--navy); border-radius: 2px; background: var(--deep); color: var(--parch);
}
.nbti-dailyword input[type="email"]::placeholder { color: var(--stone); }
.nbti-dailyword input[type="email"]:focus { outline: none; border-color: var(--gold); }
.nbti-dailyword button[type="submit"] {
  padding: 13px; font-family: var(--sans); font-size: 12px; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; background: var(--gold);
  color: var(--ink); border: none; border-radius: 2px; cursor: pointer;
}
.nbti-dailyword button[type="submit"]:hover { background: var(--gold-lt); }

/* Podcast widget item */
.nbti-poditem { display: flex; gap: 14px; align-items: center; padding: 14px 0; border-bottom: 1px solid var(--border); }
.nbti-poditem__art { width: 52px; height: 52px; flex: 0 0 auto; background: var(--ink); border-radius: 4px; display: flex; align-items: center; justify-content: center; }
.nbti-poditem__art svg { width: 22px; height: 22px; }
.nbti-poditem__title { font-family: var(--serif); font-size: 15px; font-weight: 500; line-height: 1.25; color: var(--ink); }
.nbti-poditem__meta { font-size: 11px; color: var(--muted); }

/* Shorts widget item */
.nbti-shortitem { display: flex; flex-direction: column; gap: 4px; padding: 14px 0; border-bottom: 1px solid var(--border); }
.nbti-shortitem__top { display: flex; align-items: center; gap: 8px; margin-bottom: 2px; }
.nbti-shortitem__play { width: 18px; height: 18px; background: var(--gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: var(--ink); font-size: 7px; flex: 0 0 auto; }
.nbti-shortitem__dur { font-size: 9px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); }
.nbti-shortitem__title { font-family: var(--serif); font-size: 15px; font-weight: 500; line-height: 1.25; color: var(--ink); }

/* ======================================================
   10. MISSION PULL-QUOTE
   ====================================================== */
.nbti-mission { width: 100%; background: var(--ink); margin-top: 80px; border-top: 1px solid var(--navy); }
.nbti-mission__inner {
  max-width: var(--wrap); margin: 0 auto; padding: 88px 80px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 96px; align-items: center;
}
.nbti-mission__rule { width: 36px; height: 2px; background: var(--gold); margin-bottom: 24px; }
.nbti-mission__title { font-size: 42px; line-height: 1.2; color: var(--parch); }
.nbti-mission__title em { color: var(--gold-lt); font-style: italic; }
.nbti-mission__text { font-family: var(--serif); font-style: italic; font-size: 18px; line-height: 1.6; color: var(--muted); margin: 24px 0; }
.nbti-mission__link { font-size: 13px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold-lt); display: inline-flex; gap: 6px; }
.nbti-pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--navy); border: 1px solid var(--navy); }
.nbti-pillar { background: var(--ink); padding: 28px 26px; display: flex; flex-direction: column; gap: 6px; }
.nbti-pillar__n { font-size: 10px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--gold); }
.nbti-pillar__title { font-family: var(--serif); font-size: 17px; font-weight: 500; color: var(--parch); line-height: 1.2; }
.nbti-pillar__desc { font-size: 12px; line-height: 1.5; color: var(--stone); }

/* ======================================================
   11. FOOTER (full width)
   ====================================================== */
.nbti-footer { width: 100%; background: var(--deep); border-top: 1px solid var(--ink); }
.nbti-footer__inner { max-width: var(--wrap); margin: 0 auto; padding: 64px 80px 40px; }
.nbti-footer__cols {
  display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr; gap: 40px;
  padding-bottom: 48px; border-bottom: 1px solid var(--ink);
}
.nbti-footer__brand { display: flex; flex-direction: column; gap: 16px; }
.nbti-footer__brand p { font-size: 13px; line-height: 1.6; color: var(--stone); max-width: 220px; margin: 0; }
.nbti-footer__col h4 {
  font-family: var(--sans); font-size: 11px; font-weight: 700; letter-spacing: 2px;
  text-transform: uppercase; color: var(--gold); margin: 0 0 16px;
}
.nbti-footer__col ul { list-style: none; margin: 0; padding: 0; }
.nbti-footer__col li { margin-bottom: 12px; }
.nbti-footer__col a { font-size: 13px; color: var(--stone); }
.nbti-footer__col a:hover { color: var(--parch); }
.nbti-social { display: flex; gap: 14px; flex-wrap: wrap; }
.nbti-social a { font-size: 12px; font-weight: 700; letter-spacing: .5px; color: var(--stone); }
.nbti-social a:hover { color: var(--gold-lt); }
.nbti-footer__bottom { display: flex; justify-content: space-between; align-items: center; padding-top: 24px; flex-wrap: wrap; gap: 10px; }
.nbti-footer__bottom span { font-size: 12px; color: var(--stone); }
.nbti-footer__url { font-weight: 600; letter-spacing: 1px; color: var(--gold) !important; }

/* ======================================================
   12. SINGLE POST / ARTICLE
   ====================================================== */
.nbti-article { padding-top: 56px; }
.nbti-article__header { max-width: 760px; margin: 0 auto 40px; text-align: center; }
.nbti-article__tags { display: flex; align-items: center; justify-content: center; gap: 10px; margin-bottom: 20px; }
.nbti-article__title { font-size: 46px; line-height: 1.12; margin-bottom: 18px; text-wrap: balance; }
.nbti-article__meta { display: flex; align-items: center; justify-content: center; gap: 12px; font-size: 14px; color: var(--stone); }
.nbti-article__meta .nbti-dot { color: var(--border); }
.nbti-article__hero { max-width: var(--wrap); margin: 0 auto 48px; }
.nbti-article__hero img { width: 100%; border-radius: 3px; }
.nbti-article__body {
  max-width: 720px; margin: 0 auto; font-size: 18px; line-height: 1.75; color: #2A3142;
}
.nbti-article__body p { margin: 0 0 1.4em; }
.nbti-article__body h2 { font-size: 30px; margin: 1.6em 0 .5em; }
.nbti-article__body h3 { font-size: 23px; margin: 1.4em 0 .4em; }
.nbti-article__body a { color: var(--oxblood); text-decoration: underline; text-decoration-color: var(--gold); text-underline-offset: 3px; }
.nbti-article__body blockquote {
  margin: 1.6em 0; padding: 6px 0 6px 28px; border-left: 3px solid var(--gold);
  font-family: var(--serif); font-style: italic; font-size: 23px; line-height: 1.5; color: var(--ink);
}
.nbti-article__body img { border-radius: 3px; margin: 1.5em 0; }
.nbti-article__body ul, .nbti-article__body ol { margin: 0 0 1.4em; padding-left: 1.4em; }
.nbti-article__body li { margin-bottom: .5em; }
.nbti-article__body .wp-block-pullquote,
.nbti-article__body figure { margin: 1.6em 0; }
.nbti-article__footer { max-width: 720px; margin: 48px auto 0; padding-top: 28px; border-top: 1px solid var(--border); }
.nbti-tags-list { display: flex; flex-wrap: wrap; gap: 8px; }
.nbti-tags-list a {
  font-size: 12px; font-weight: 600; color: var(--stone); background: var(--white);
  border: 1px solid var(--border); padding: 5px 12px; border-radius: 2px;
}
.nbti-tags-list a:hover { border-color: var(--gold); color: var(--gold); }

/* Author box */
.nbti-author-box {
  max-width: 720px; margin: 40px auto 0; padding: 28px; background: var(--white);
  border: 1px solid var(--border); border-radius: 3px; display: flex; gap: 20px; align-items: flex-start;
}
.nbti-author-box__avatar { flex: 0 0 auto; border-radius: 50%; overflow: hidden; width: 64px; height: 64px; background: var(--ink); }
.nbti-author-box__name { font-family: var(--serif); font-size: 19px; font-weight: 500; margin-bottom: 4px; }
.nbti-author-box__bio { font-size: 14px; line-height: 1.6; color: var(--stone); margin: 0; }

/* Post navigation */
.nbti-postnav { max-width: 720px; margin: 40px auto 0; display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.nbti-postnav a { display: flex; flex-direction: column; gap: 6px; padding: 20px 24px; background: var(--white); border: 1px solid var(--border); border-radius: 3px; }
.nbti-postnav a:hover { border-color: var(--gold); }
.nbti-postnav__label { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--gold); }
.nbti-postnav__title { font-family: var(--serif); font-size: 16px; color: var(--ink); line-height: 1.25; }
.nbti-postnav__next { text-align: right; }

/* ======================================================
   13. ARCHIVE / SEARCH / INDEX
   ====================================================== */
.nbti-page-header { width: 100%; background: var(--ink); }
.nbti-page-header__inner { max-width: var(--wrap); margin: 0 auto; padding: 56px 80px; }
.nbti-page-header__eyebrow { font-size: 12px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-bottom: 14px; }
.nbti-page-header__title { font-size: 52px; line-height: 1.05; color: var(--parch); }
.nbti-page-header__desc { font-family: var(--serif); font-style: italic; font-size: 19px; color: var(--muted); margin-top: 16px; max-width: 620px; }

/* Pagination */
.nbti-pagination { margin: 48px 0; display: flex; justify-content: center; gap: 8px; }
.nbti-pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center; min-width: 42px; height: 42px;
  padding: 0 14px; font-size: 14px; font-weight: 600; color: var(--stone);
  border: 1px solid var(--border); border-radius: 2px; background: var(--white);
}
.nbti-pagination .page-numbers.current,
.nbti-pagination .page-numbers:hover { background: var(--gold); color: var(--ink); border-color: var(--gold); }

/* ======================================================
   14. PAGE (generic) + designed templates
   ====================================================== */
.nbti-page { padding: 56px 0 80px; }
.nbti-page__body { max-width: 760px; margin: 0 auto; font-size: 18px; line-height: 1.75; color: #2A3142; }
.nbti-page__body h2 { font-size: 30px; margin: 1.4em 0 .5em; }
.nbti-page__body h3 { font-size: 23px; margin: 1.2em 0 .4em; }

/* About template */
.nbti-about-hero { width: 100%; background: var(--ink); }
.nbti-about-hero__inner { max-width: var(--wrap); margin: 0 auto; padding: 88px 80px; display: grid; grid-template-columns: 1.2fr 1fr; gap: 80px; align-items: center; }
.nbti-about-hero__mark { display: flex; justify-content: center; }
.nbti-about-hero__mark svg { width: 240px; height: 240px; }
.nbti-about-hero h1 { font-size: 56px; line-height: 1.05; color: var(--parch); margin-bottom: 20px; }
.nbti-about-hero p { font-family: var(--serif); font-style: italic; font-size: 21px; line-height: 1.55; color: var(--muted); }
.nbti-about-pillars { max-width: var(--wrap); margin: 0 auto; padding: 80px 80px; display: grid; grid-template-columns: repeat(4,1fr); gap: 28px; }
.nbti-about-pillar { background: var(--white); border: 1px solid var(--border); border-top: 3px solid var(--gold); border-radius: 3px; padding: 32px 28px; }
.nbti-about-pillar__n { font-size: 12px; font-weight: 700; letter-spacing: 2px; color: var(--gold); }
.nbti-about-pillar__title { font-family: var(--serif); font-size: 22px; margin: 10px 0 8px; }
.nbti-about-pillar__desc { font-size: 14px; line-height: 1.6; color: var(--stone); }

/* Resources hub */
.nbti-reshub { max-width: var(--wrap); margin: 0 auto; padding: 56px 80px 80px; display: grid; grid-template-columns: repeat(3,1fr); gap: 24px; }
.nbti-rescard { background: var(--white); border: 1px solid var(--border); border-radius: 4px; overflow: hidden; display: flex; flex-direction: column; }
.nbti-rescard:hover { box-shadow: 0 8px 32px rgba(22,29,51,.1); }
.nbti-rescard__tile { height: 140px; display: flex; align-items: flex-end; justify-content: space-between; padding: 18px 20px; }
.nbti-rescard__cat { font-size: 10px; font-weight: 700; letter-spacing: 2.5px; text-transform: uppercase; color: var(--gold-lt); }
.nbti-rescard__tile svg { width: 42px; height: 42px; opacity: .18; }
.nbti-rescard__body { padding: 22px 24px 26px; display: flex; flex-direction: column; gap: 8px; flex: 1; }
.nbti-rescard__title { font-family: var(--sans); font-size: 18px; font-weight: 700; color: var(--ink); }
.nbti-rescard__desc { font-size: 14px; line-height: 1.55; color: var(--stone); flex: 1; }
.nbti-rescard__link { font-size: 13px; font-weight: 700; color: var(--gold); letter-spacing: .5px; }

/* 404 */
.nbti-404 { max-width: 640px; margin: 0 auto; padding: 100px 80px; text-align: center; }
.nbti-404 svg { width: 120px; height: 120px; margin: 0 auto 32px; opacity: .9; }
.nbti-404__code { font-size: 13px; font-weight: 700; letter-spacing: 3px; text-transform: uppercase; color: var(--gold); margin-bottom: 16px; }
.nbti-404 h1 { font-size: 44px; margin-bottom: 16px; }
.nbti-404 p { font-size: 17px; color: var(--stone); margin-bottom: 32px; }

/* Comments */
.nbti-comments { max-width: 720px; margin: 56px auto 0; padding-top: 40px; border-top: 2px solid var(--ink); }
.nbti-comments__title { font-size: 26px; margin-bottom: 28px; }
.nbti-comments .comment-list { list-style: none; margin: 0; padding: 0; }
.nbti-comments .comment-list li { padding: 20px 0; border-bottom: 1px solid var(--border); }
.nbti-comments .comment-author { font-family: var(--serif); font-weight: 600; font-size: 16px; }
.nbti-comments .comment-meta { font-size: 12px; color: var(--muted); margin-bottom: 8px; }
.nbti-comments .comment-respond { margin-top: 32px; }
.nbti-comments input[type="text"], .nbti-comments input[type="email"], .nbti-comments input[type="url"], .nbti-comments textarea {
  width: 100%; padding: 12px 14px; font-family: var(--sans); font-size: 15px;
  border: 1px solid var(--border); border-radius: 2px; background: var(--white); margin-bottom: 14px;
}
.nbti-comments .form-submit input { font-family: var(--sans); font-size: 13px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; background: var(--gold); color: var(--ink); border: none; padding: 14px 28px; border-radius: 2px; cursor: pointer; }

/* Search form */
.nbti-searchform { display: flex; gap: 8px; }
.nbti-searchform input[type="search"] { flex: 1; padding: 12px 16px; font-family: var(--sans); font-size: 15px; border: 1px solid var(--border); border-radius: 2px; background: var(--white); }
.nbti-searchform button { font-family: var(--sans); font-size: 13px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; background: var(--gold); color: var(--ink); border: none; padding: 0 22px; border-radius: 2px; cursor: pointer; }

/* ======================================================
   15. RESPONSIVE
   ====================================================== */
@media (max-width: 1100px) {
  :root { --gap: 40px; }
  .nbti-wrap, .nbti-nav__inner, .nbti-hero__inner, .nbti-features__inner,
  .nbti-main, .nbti-mission__inner, .nbti-footer__inner, .nbti-page-header__inner,
  .nbti-about-hero__inner, .nbti-about-pillars, .nbti-reshub { padding-left: 40px; padding-right: 40px; }
  .nbti-announce__inner { padding-left: 40px; padding-right: 40px; }
  .nbti-hero__inner { grid-template-columns: 1fr; }
  .nbti-hero__feature { border-right: 0; border-bottom: 1px solid var(--navy); padding: 48px 0; }
  .nbti-hero__recent { padding: 32px 0; }
  .nbti-main { grid-template-columns: 1fr; }
  .nbti-sidebar { border-top: 2px solid var(--ink); margin-top: 40px; }
  .nbti-mission__inner { grid-template-columns: 1fr; gap: 48px; }
  .nbti-about-hero__inner { grid-template-columns: 1fr; gap: 48px; }
  .nbti-about-pillars { grid-template-columns: repeat(2,1fr); }
  .nbti-footer__cols { grid-template-columns: 1fr 1fr 1fr; }
  .nbti-footer__brand { grid-column: 1 / -1; }
}
@media (max-width: 860px) {
  .nbti-nav__menu { display: none; }
  .nbti-nav__toggle { display: flex; }
  .nbti-nav__menu.is-open {
    display: block; position: absolute; top: 64px; left: 0; right: 0;
    background: var(--ink); border-bottom: 1px solid var(--navy); padding: 8px 40px 20px;
  }
  .nbti-nav__menu.is-open .nbti-menu { flex-direction: column; align-items: stretch; }
  .nbti-nav__menu.is-open .nbti-menu > li > a { height: auto; padding: 14px 0; border-bottom: 1px solid var(--navy); }
  .nbti-nav__menu.is-open .sub-menu { position: static; opacity: 1; visibility: visible; transform: none; box-shadow: none; border-top: 0; padding: 0 0 8px 16px; }
  .nbti-features__inner { grid-template-columns: 1fr 1fr; }
  .nbti-feature:nth-child(2) { border-right: 0; }
  .nbti-cards3 { grid-template-columns: 1fr; }
  .nbti-reshub { grid-template-columns: 1fr 1fr; }
  .nbti-hero__title { font-size: 38px; }
  .nbti-feed__item { grid-template-columns: 1fr; }
  .nbti-feed__thumb { display: none; }
  .nbti-article__title { font-size: 34px; }
  .nbti-postnav { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .nbti-wrap, .nbti-nav__inner, .nbti-hero__inner, .nbti-features__inner,
  .nbti-main, .nbti-mission__inner, .nbti-footer__inner, .nbti-page-header__inner,
  .nbti-about-hero__inner, .nbti-about-pillars, .nbti-reshub, .nbti-announce__inner { padding-left: 24px; padding-right: 24px; }
  .nbti-features__inner { grid-template-columns: 1fr; }
  .nbti-feature { border-right: 0; }
  .nbti-footer__cols { grid-template-columns: 1fr 1fr; }
  .nbti-about-pillars, .nbti-reshub { grid-template-columns: 1fr; }
  .nbti-page-header__title { font-size: 36px; }
  .nbti-pillars { grid-template-columns: 1fr; }
  .nbti-announce__inner { flex-direction: column; gap: 4px; }
}
