/*
Theme Name:   NBT Trading
Theme URI:    https://nobelltrading.com
Description:  NoBell Trading — Full custom WordPress theme. No Elementor. Pure NBT Intelligence Division design system.
Author:       Depache
Author URI:   https://nobelltrading.com
Version:      1.0.0
Text Domain:  nbt-trading
License:      GPL-2.0-or-later
Tags:         custom-colors, custom-menu, custom-logo, full-width-template, dark
*/

/* ============================================================
   NBT DESIGN SYSTEM — CSS CUSTOM PROPERTIES
   Single source of truth for all colors, spacing, typography.
   ============================================================ */
:root {
  /* Core backgrounds */
  --nbt-bg-base:       #07080c;
  --nbt-bg-card:       #0c0e14;
  --nbt-bg-elevated:   #111420;
  --nbt-bg-overlay:    rgba(7, 8, 12, 0.94);

  /* Brand — Gold (primary) */
  --nbt-gold:          #C9A84C;
  --nbt-gold-bright:   #F5D155;
  --nbt-gold-dim:      #7A6428;
  --nbt-gold-glow:     rgba(201, 168, 76, 0.55);

  /* Trading colors */
  --nbt-green:         #00E87A;
  --nbt-green-glow:    rgba(0, 232, 122, 0.45);
  --nbt-red:           #FF3B30;
  --nbt-red-glow:      rgba(255, 59, 48, 0.45);

  /* Accent palette */
  --nbt-blue:          #00BFFF;
  --nbt-blue-glow:     rgba(0, 191, 255, 0.35);
  --nbt-amber:         #FF9500;
  --nbt-amber-glow:    rgba(255, 149, 0, 0.4);
  --nbt-purple:        #9B6DFF;
  --nbt-purple-glow:   rgba(155, 109, 255, 0.35);

  /* Text */
  --nbt-text:          #EDE8D8;
  --nbt-text-dim:      #8A7D6A;
  --nbt-text-faint:    #4A4035;

  /* Borders */
  --nbt-border-gold:   rgba(201, 168, 76, 0.38);
  --nbt-border-faint:  rgba(201, 168, 76, 0.12);

  /* Spacing */
  --nbt-section-pad:   80px 32px;
  --nbt-max-w:         1280px;
  --nbt-radius:        0px;

  /* Typography */
  --nbt-font-display:  'Orbitron', sans-serif;
  --nbt-font-body:     'Rajdhani', sans-serif;
  --nbt-font-mono:     'Share Tech Mono', monospace;

  /* ------------------------------------------------------------
     COMPAT ALIASES — short-form names used by inline styles in
     template-*.php. These ensure inline style="color:var(--gold)"
     etc. continue to resolve even if the templates use the legacy
     naming. New CSS should always use the nbt- prefixed vars above.
     ------------------------------------------------------------ */
  --gold:           var(--nbt-gold);
  --gold-bright:    var(--nbt-gold-bright);
  --gold-dim:       var(--nbt-gold-dim);
  --glow-gold:      var(--nbt-gold-glow);
  --neon-green:     var(--nbt-green);
  --glow-green:     var(--nbt-green-glow);
  --neon-red:       var(--nbt-red);
  --glow-red:       var(--nbt-red-glow);
  --electric-blue:  var(--nbt-blue);
  --glow-blue:      var(--nbt-blue-glow);
  --amber:          var(--nbt-amber);
  --purple:         var(--nbt-purple);
  --bg-base:        var(--nbt-bg-base);
  --bg-card:        var(--nbt-bg-card);
  --text:           var(--nbt-text);
  --text-dim:       var(--nbt-text-dim);
  --text-faint:     var(--nbt-text-faint);
  --border-gold:    var(--nbt-border-gold);
  --border-faint:   var(--nbt-border-faint);
}

/* ============================================================
   GLOBAL RESET & BASE
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: var(--nbt-bg-base) !important;
  color: var(--nbt-text) !important;
  font-family: var(--nbt-font-body) !important;
  font-size: 16px;
  line-height: 1.6;
  overflow-x: hidden;
  min-height: 100vh;
}

/* Scanline overlay — subtle CRT texture */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background: repeating-linear-gradient(
    0deg,
    rgba(0, 0, 0, 0) 0px,
    rgba(0, 0, 0, 0) 2px,
    rgba(0, 0, 0, 0.032) 3px,
    rgba(0, 0, 0, 0) 4px
  );
  z-index: 9998;
  mix-blend-mode: multiply;
}

/* Ambient glow — gold top-left, blue bottom-right, purple bottom-center */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 12% 18%, rgba(201, 168, 76, 0.055), transparent 38%),
    radial-gradient(circle at 88% 72%, rgba(0, 191, 255, 0.032), transparent 38%),
    radial-gradient(circle at 55% 90%, rgba(155, 109, 255, 0.03), transparent 30%);
  z-index: -1;
}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--nbt-font-display) !important;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--nbt-text);
  line-height: 1.15;
}

p, li, td, th, label {
  font-family: var(--nbt-font-body);
}

code, pre, .mono, [class*="mono"] {
  font-family: var(--nbt-font-mono) !important;
}

a {
  color: var(--nbt-gold);
  text-decoration: none;
  transition: color 0.2s ease;
}
a:hover {
  color: var(--nbt-gold-bright);
}

/* Custom scrollbar */
::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--nbt-bg-base); }
::-webkit-scrollbar-thumb { background: var(--nbt-gold-dim); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--nbt-gold); }

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

/* ============================================================
   TICKER TAPE BAR
   Fixed at very top, 56px tall (matches TradingView compact render height)
   ============================================================ */
.nbt-ticker-bar {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 72px;
  overflow: hidden;
  z-index: 10001;
  background: rgba(7, 8, 12, 0.98);
  border-bottom: 1px solid var(--nbt-border-gold);
}
/* Force TradingView ticker iframe to match bar height */
.nbt-ticker-bar .tradingview-widget-container,
.nbt-ticker-bar .tradingview-widget-container__widget,
.nbt-ticker-bar iframe {
  height: 72px !important;
  max-height: 72px !important;
  overflow: hidden !important;
}

.nbt-ticker-wrap {
  display: flex;
  align-items: center;
  overflow: hidden;
  height: 100%;
}

.nbt-ticker-label {
  flex-shrink: 0;
  padding: 0 16px;
  font-family: var(--nbt-font-mono);
  font-size: 0.68rem;
  color: var(--nbt-gold);
  letter-spacing: 0.2em;
  border-right: 1px solid var(--nbt-border-gold);
  height: 100%;
  display: flex;
  align-items: center;
  background: rgba(201, 168, 76, 0.06);
  text-shadow: 0 0 8px var(--nbt-gold-glow);
  white-space: nowrap;
}

.nbt-ticker-track {
  display: flex;
  animation: nbt-ticker-scroll 60s linear infinite;
  white-space: nowrap;
  will-change: transform;
}

.nbt-ticker-item {
  font-family: var(--nbt-font-mono);
  font-size: 0.72rem;
  padding: 0 24px;
  letter-spacing: 0.06em;
  display: flex;
  gap: 8px;
  align-items: center;
}

.nbt-ticker-sym   { color: var(--nbt-text); font-weight: 600; }
.nbt-ticker-price { color: var(--nbt-text-dim); }
.nbt-ticker-up    { color: var(--nbt-green); text-shadow: 0 0 5px var(--nbt-green-glow); }
.nbt-ticker-dn    { color: var(--nbt-red);   text-shadow: 0 0 5px var(--nbt-red-glow); }
.nbt-ticker-sep   { color: var(--nbt-text-faint); }

/* ============================================================
   NAVBAR
   Fixed below ticker, 64px tall, total header = 144px
   ============================================================ */
.nbt-navbar {
  position: fixed;
  top: 80px;
  left: 0;
  right: 0;
  height: 64px;
  z-index: 10000;
  background: rgba(7, 8, 12, 0.88);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--nbt-border-gold);
  box-shadow: 0 0 28px rgba(201, 168, 76, 0.12);
  display: flex;
  align-items: center;
  padding: 0 32px;
  gap: 24px;
}

/* Logo area */
.nbt-nav-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  flex-shrink: 0;
}

.nbt-logo-img {
  height: 40px;
  width: 40px;
  object-fit: contain;
  filter: drop-shadow(0 0 8px rgba(201, 168, 76, 0.6));
  transition: filter 0.3s ease;
}
.nbt-logo-img:hover {
  filter: drop-shadow(0 0 14px rgba(201, 168, 76, 0.9));
}

.nbt-logo-text-wrap {
  display: flex;
  flex-direction: column;
  line-height: 1;
}

.nbt-logo-text {
  font-family: var(--nbt-font-display) !important;
  font-weight: 900;
  font-size: 1.4rem;
  letter-spacing: 0.14em;
  background: linear-gradient(90deg, #7A6428, #C9A84C 28%, #F5D155 50%, #C9A84C 72%, #7A6428);
  background-size: 200%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: nbt-gold-shine 4s linear infinite;
  filter: drop-shadow(0 0 8px rgba(201, 168, 76, 0.5));
  will-change: background-position;
}

.nbt-logo-tagline {
  font-family: var(--nbt-font-mono);
  font-size: 0.58rem;
  color: var(--nbt-text-faint);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  margin-top: 2px;
}

/* Primary nav menu */
.nbt-primary-nav {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 4px;
}

.nbt-primary-nav ul {
  list-style: none;
  display: flex;
  align-items: center;
  gap: 4px;
}

.nbt-primary-nav ul li a,
.nbt-primary-nav ul li > span {
  font-family: var(--nbt-font-body) !important;
  font-weight: 600 !important;
  font-size: 0.83rem !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase !important;
  color: var(--nbt-text-dim) !important;
  padding: 6px 12px;
  display: block;
  border-bottom: 1px solid transparent;
  transition: all 0.22s ease;
  text-decoration: none;
}

.nbt-primary-nav ul li a:hover,
.nbt-primary-nav ul li.current-menu-item > a,
.nbt-primary-nav ul li.current-page-ancestor > a,
.nbt-primary-nav ul li.current-menu-ancestor > a {
  color: var(--nbt-gold-bright) !important;
  text-shadow: 0 0 10px var(--nbt-gold-glow) !important;
  border-bottom-color: var(--nbt-gold) !important;
}

/* Dropdown submenus */
.nbt-primary-nav ul li {
  position: relative;
}

.nbt-primary-nav ul li ul {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  min-width: 200px;
  background: rgba(7, 8, 12, 0.97);
  border: 1px solid var(--nbt-border-gold);
  border-top: 2px solid var(--nbt-gold);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.7);
  z-index: 1000;
  flex-direction: column;
  gap: 0;
}

.nbt-primary-nav ul li:hover > ul {
  display: flex;
}

.nbt-primary-nav ul li ul li a {
  border-bottom: 1px solid var(--nbt-border-faint) !important;
  width: 100%;
}

/* Member Portal CTA button */
.nbt-nav-portal-btn {
  flex-shrink: 0;
  margin-left: 8px;
}

.nbt-nav-portal-btn a {
  display: inline-block;
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.18), rgba(201, 168, 76, 0.06)) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  color: var(--nbt-gold-bright) !important;
  font-family: var(--nbt-font-display) !important;
  font-size: 0.76rem !important;
  letter-spacing: 0.18em !important;
  padding: 8px 20px !important;
  text-transform: uppercase;
  text-decoration: none;
  transition: all 0.25s ease;
  text-shadow: 0 0 8px var(--nbt-gold-glow);
  box-shadow: 0 0 14px rgba(201, 168, 76, 0.1);
}

.nbt-nav-portal-btn a:hover {
  background: rgba(201, 168, 76, 0.28) !important;
  box-shadow: 0 0 22px rgba(201, 168, 76, 0.3) !important;
}

/* ============================================================
   MEMBER DROPDOWN — shown when logged in
   ============================================================ */
.nbt-member-dropdown { position: relative; flex-shrink: 0; }

.nbt-member-trigger {
  display: inline-block;
  background: linear-gradient(135deg, rgba(201,168,76,0.18), rgba(201,168,76,0.06));
  border: 1px solid var(--nbt-border-gold);
  color: var(--nbt-gold-bright);
  font-family: var(--nbt-font-display);
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  padding: 8px 16px;
  cursor: pointer;
  text-shadow: 0 0 8px var(--nbt-gold-glow);
  box-shadow: 0 0 14px rgba(201,168,76,0.1);
  transition: all 0.25s;
  white-space: nowrap;
}
.nbt-member-trigger:hover,
.nbt-member-dropdown.open .nbt-member-trigger {
  background: rgba(201,168,76,0.28);
  box-shadow: 0 0 22px rgba(201,168,76,0.3);
}
.nbt-member-caret { font-size: 0.6rem; margin-left: 4px; }

.nbt-member-menu {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 190px;
  background: rgba(7,8,12,0.98);
  border: 1px solid var(--nbt-border-gold);
  box-shadow: 0 8px 32px rgba(201,168,76,0.15);
  z-index: 10002;
  overflow: hidden;
}
.nbt-member-dropdown.open .nbt-member-menu { display: block; }

.nbt-member-menu a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  font-family: var(--nbt-font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.14em;
  color: var(--nbt-text-dim);
  text-decoration: none;
  transition: all 0.2s;
  border-bottom: 1px solid var(--nbt-border-faint);
}
.nbt-member-menu a:last-child { border-bottom: none; }
.nbt-member-menu a:hover { color: var(--nbt-gold-bright); background: rgba(201,168,76,0.07); }
.nbt-member-menu-icon { color: var(--nbt-gold-dim); font-size: 0.65rem; }
.nbt-member-menu-divider { height: 1px; background: var(--nbt-border-gold); margin: 2px 0; }
.nbt-member-logout { color: var(--nbt-text-faint) !important; }
.nbt-member-logout:hover { color: var(--nbt-red) !important; background: rgba(255,59,48,0.06) !important; }

/* Mobile hamburger toggle */
.nbt-nav-toggle {
  display: none;
  background: transparent;
  border: 1px solid var(--nbt-border-gold);
  color: var(--nbt-gold);
  padding: 6px 14px;
  font-family: var(--nbt-font-mono);
  font-size: 0.82rem;
  cursor: pointer;
  margin-left: auto;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}
.nbt-nav-toggle:hover {
  background: rgba(201, 168, 76, 0.1);
}

/* ============================================================
   PAGE BODY OFFSET — push content below fixed header
   ============================================================ */
.nbt-page-wrap {
  padding-top: 144px;
  min-height: 100vh;
}

/* ============================================================
   LAYOUT UTILITIES
   ============================================================ */
.nbt-container {
  max-width: var(--nbt-max-w);
  margin: 0 auto;
  padding: 0 32px;
}

.nbt-section {
  padding: 80px 0;
}

.nbt-section-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--nbt-border-gold), transparent);
  margin: 0;
  border: none;
}

.nbt-section-tag {
  display: inline-block;
  font-family: var(--nbt-font-mono);
  color: var(--nbt-gold);
  font-size: 0.73rem;
  letter-spacing: 0.32em;
  margin-bottom: 12px;
  border-left: 2px solid var(--nbt-gold);
  padding-left: 10px;
  text-shadow: 0 0 8px var(--nbt-gold-glow);
}

.nbt-section-title {
  font-size: clamp(1.7rem, 3.5vw, 2.6rem);
  margin-bottom: 20px;
  color: var(--nbt-text);
  text-shadow: 0 0 20px rgba(201, 168, 76, 0.2);
}

.nbt-section-intro {
  font-size: 1.08rem;
  color: var(--nbt-text-dim);
  max-width: 860px;
  margin-bottom: 28px;
  line-height: 1.75;
}

.gold   { color: var(--nbt-gold-bright); text-shadow: 0 0 18px var(--nbt-gold-glow); }
.green  { color: var(--nbt-green);       text-shadow: 0 0 18px var(--nbt-green-glow); }
.blue   { color: var(--nbt-blue);        text-shadow: 0 0 18px var(--nbt-blue-glow); }
.amber  { color: var(--nbt-amber);       text-shadow: 0 0 18px var(--nbt-amber-glow); }
.purple { color: var(--nbt-purple);      text-shadow: 0 0 18px var(--nbt-purple-glow); }

/* ============================================================
   CARD COMPONENTS
   ============================================================ */
.nbt-card {
  background: var(--nbt-bg-card);
  border: 1px solid var(--nbt-border-gold);
  box-shadow: 0 0 18px rgba(201, 168, 76, 0.08);
  padding: 28px 24px;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  contain: layout style;
}

.nbt-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--nbt-gold), transparent);
}

.nbt-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 32px rgba(201, 168, 76, 0.18);
}

.nbt-card.green-card  { border-color: rgba(0, 232, 122, 0.35); }
.nbt-card.green-card::before  { background: linear-gradient(90deg, transparent, var(--nbt-green), transparent); }
.nbt-card.blue-card   { border-color: rgba(0, 191, 255, 0.35); }
.nbt-card.blue-card::before   { background: linear-gradient(90deg, transparent, var(--nbt-blue), transparent); }
.nbt-card.purple-card { border-color: rgba(155, 109, 255, 0.35); }
.nbt-card.purple-card::before { background: linear-gradient(90deg, transparent, var(--nbt-purple), transparent); }
.nbt-card.amber-card  { border-color: rgba(255, 149, 0, 0.35); }
.nbt-card.amber-card::before  { background: linear-gradient(90deg, transparent, var(--nbt-amber), transparent); }

/* ============================================================
   BUTTONS
   ============================================================ */
.nbt-btn-primary {
  display: inline-block;
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.22), rgba(201, 168, 76, 0.08));
  border: 1px solid var(--nbt-gold);
  color: var(--nbt-gold-bright) !important;
  font-family: var(--nbt-font-display) !important;
  font-weight: 700;
  font-size: 0.82rem;
  letter-spacing: 0.18em;
  padding: 14px 32px;
  cursor: pointer;
  transition: all 0.25s ease;
  text-transform: uppercase;
  text-decoration: none !important;
  box-shadow: 0 0 18px rgba(201, 168, 76, 0.15);
}

.nbt-btn-primary:hover {
  background: rgba(201, 168, 76, 0.28);
  box-shadow: 0 0 32px rgba(201, 168, 76, 0.35);
  transform: translateY(-1px);
  color: var(--nbt-gold-bright) !important;
}

.nbt-btn-secondary {
  display: inline-block;
  background: transparent;
  border: 1px solid var(--nbt-border-gold);
  color: var(--nbt-text-dim) !important;
  font-family: var(--nbt-font-display) !important;
  font-size: 0.82rem;
  letter-spacing: 0.18em;
  padding: 14px 32px;
  cursor: pointer;
  transition: all 0.25s ease;
  text-transform: uppercase;
  text-decoration: none !important;
}

.nbt-btn-secondary:hover {
  border-color: var(--nbt-gold);
  color: var(--nbt-gold) !important;
  box-shadow: 0 0 18px rgba(201, 168, 76, 0.12);
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.nbt-hero {
  position: relative;
  min-height: calc(100vh - 96px);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  padding: 60px 32px 40px;
  overflow: hidden;
}

#nbt-candles-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.28;
  pointer-events: none;
  z-index: 0;
  will-change: transform;
  -webkit-mask-image: linear-gradient(to right, transparent 0%, rgba(0,0,0,0.15) 6%, rgba(0,0,0,0.7) 16%, black 28%, black 100%);
  mask-image: linear-gradient(to right, transparent 0%, rgba(0,0,0,0.15) 6%, rgba(0,0,0,0.7) 16%, black 28%, black 100%);
}

.nbt-hero-content {
  position: relative;
  z-index: 1;
  max-width: 1100px;
  width: 100%;
}

.nbt-hero-pretitle {
  font-family: var(--nbt-font-mono);
  color: var(--nbt-gold-bright);
  font-size: 0.88rem;
  letter-spacing: 0.45em;
  margin-bottom: 16px;
  text-shadow: 0 0 10px var(--nbt-gold-glow);
  animation: nbt-flicker 8s infinite alternate;
}

.nbt-hero-title {
  font-family: var(--nbt-font-display) !important;
  font-weight: 900;
  font-size: clamp(2.6rem, 8vw, 6rem);
  line-height: 1.0;
  background: linear-gradient(135deg, #7A6428 0%, #C9A84C 30%, #F5D155 50%, #C9A84C 70%, #7A6428 100%);
  background-size: 200%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: nbt-gold-shine 5s linear infinite;
  filter: drop-shadow(0 0 22px rgba(201, 168, 76, 0.65));
  letter-spacing: 0.06em;
  margin-bottom: 12px;
}

.nbt-hero-subtitle {
  font-family: var(--nbt-font-display) !important;
  font-weight: 500;
  font-size: clamp(0.9rem, 1.8vw, 1.35rem);
  color: var(--nbt-text-dim);
  letter-spacing: 0.2em;
  margin-bottom: 52px;
}

.nbt-hero-subtitle span { color: var(--nbt-gold); }

/* Hero stat cards */
.nbt-hero-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  max-width: 900px;
  margin: 0 auto 48px;
}

.nbt-stat-card {
  background: rgba(12, 14, 20, 0.85);
  border: 1px solid var(--nbt-border-gold);
  box-shadow: 0 0 20px rgba(201, 168, 76, 0.12), inset 0 0 20px rgba(201, 168, 76, 0.04);
  padding: 26px 16px;
  position: relative;
  overflow: hidden;
  contain: layout style;
}

.nbt-stat-card::after {
  content: '';
  position: absolute;
  inset: -1px;
  pointer-events: none;
  border: 1px solid rgba(201, 168, 76, 0.7);
  box-shadow: 0 0 28px rgba(201, 168, 76, 0.3);
  opacity: 0;
  animation: nbt-glow-pulse 6s ease-in-out infinite;
}

.nbt-stat-card:nth-child(2) { border-color: rgba(0, 232, 122, 0.35); }
.nbt-stat-card:nth-child(2)::after { border-color: rgba(0,232,122,.7); box-shadow: 0 0 28px var(--nbt-green-glow); animation-delay: -2s; }
.nbt-stat-card:nth-child(3) { border-color: rgba(0, 191, 255, 0.35); }
.nbt-stat-card:nth-child(3)::after { border-color: rgba(0,191,255,.7); box-shadow: 0 0 28px var(--nbt-blue-glow); animation-delay: -4s; }

.nbt-stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--nbt-gold), transparent);
  animation: nbt-scan-h 6s infinite linear;
}
.nbt-stat-card:nth-child(2)::before { background: linear-gradient(90deg, transparent, var(--nbt-green), transparent); }
.nbt-stat-card:nth-child(3)::before { background: linear-gradient(90deg, transparent, var(--nbt-blue), transparent); }

.nbt-stat-value {
  font-family: var(--nbt-font-mono);
  font-size: clamp(1.9rem, 4vw, 3.2rem);
  color: var(--nbt-gold-bright);
  text-shadow: 0 0 16px var(--nbt-gold-glow);
  margin-bottom: 6px;
  line-height: 1;
}
.nbt-stat-card:nth-child(2) .nbt-stat-value { color: var(--nbt-green);  text-shadow: 0 0 16px var(--nbt-green-glow); }
.nbt-stat-card:nth-child(3) .nbt-stat-value { color: var(--nbt-blue);   text-shadow: 0 0 16px var(--nbt-blue-glow); }

.nbt-stat-label {
  font-family: var(--nbt-font-body);
  color: var(--nbt-text-dim);
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  margin-top: 8px;
}

.nbt-hero-cta-row {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
}

/* ============================================================
   PILLAR CARDS (Home Feature section)
   ============================================================ */
.nbt-pillars-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 32px;
}

.nbt-pillar {
  background: var(--nbt-bg-card);
  border: 1px solid var(--nbt-border-gold);
  padding: 32px 24px;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  contain: layout style;
}
.nbt-pillar:hover { transform: translateY(-3px); box-shadow: 0 0 36px rgba(201, 168, 76, 0.18); }
.nbt-pillar::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--nbt-gold), transparent);
}
.nbt-pillar-icon { font-size: 2rem; margin-bottom: 16px; display: block; }
.nbt-pillar h3 { color: var(--nbt-gold-bright); font-size: 1.05rem; letter-spacing: 0.1em; margin-bottom: 10px; text-shadow: 0 0 8px var(--nbt-gold-glow); }
.nbt-pillar p  { color: var(--nbt-text-dim); font-size: 0.97rem; line-height: 1.7; }

/* ============================================================
   PARTNER BADGES
   ============================================================ */
.nbt-partners-row {
  display: flex;
  gap: 32px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 28px;
}

.nbt-partner-badge {
  font-family: var(--nbt-font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.2em;
  color: var(--nbt-text-faint);
  padding: 10px 22px;
  border: 1px solid rgba(201, 168, 76, 0.12);
  transition: all 0.25s ease;
}
.nbt-partner-badge:hover { color: var(--nbt-gold-dim); border-color: var(--nbt-border-gold); }

/* ============================================================
   HARD CLOSER CTA SECTION
   ============================================================ */
.nbt-closer-section {
  background: rgba(7, 8, 12, 0.98);
  border-top: 1px solid var(--nbt-border-gold);
  border-bottom: 1px solid var(--nbt-border-gold);
  box-shadow: 0 0 60px rgba(201, 168, 76, 0.12), inset 0 0 80px rgba(201, 168, 76, 0.04);
  padding: 80px 32px;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.nbt-closer-section::before {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(ellipse at center, rgba(201, 168, 76, 0.07) 0%, transparent 65%);
}

.nbt-closer-inner {
  position: relative;
  z-index: 1;
  max-width: 780px;
  margin: 0 auto;
}

.nbt-closer-title {
  font-family: var(--nbt-font-display) !important;
  font-weight: 900;
  font-size: clamp(2rem, 5vw, 3.4rem);
  color: var(--nbt-gold-bright);
  text-shadow: 0 0 28px var(--nbt-gold-glow);
  letter-spacing: 0.08em;
  margin-bottom: 20px;
  line-height: 1.1;
}

.nbt-closer-sub {
  font-size: 1.18rem;
  color: var(--nbt-text-dim);
  max-width: 560px;
  margin: 0 auto 36px;
  line-height: 1.7;
}

.nbt-closer-cta-row {
  display: flex;
  gap: 20px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.nbt-closer-fine {
  font-family: var(--nbt-font-mono);
  font-size: 0.72rem;
  color: var(--nbt-text-faint);
  letter-spacing: 0.18em;
}

/* ============================================================
   BOT CARDS — The Division / Our AIs
   ============================================================ */
.nbt-bot-hero {
  padding: 60px 0 32px;
  border-bottom: 1px solid var(--nbt-border-faint);
  margin-bottom: 56px;
}

.nbt-ai-class-badge {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  background: rgba(155, 109, 255, 0.08);
  border: 1px solid rgba(155, 109, 255, 0.3);
  padding: 8px 20px;
  margin-bottom: 28px;
  font-family: var(--nbt-font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.28em;
  color: var(--nbt-purple);
  text-shadow: 0 0 8px rgba(155, 109, 255, 0.5);
}
.nbt-ai-class-badge::before {
  content: '◈';
  animation: nbt-pulse-dot 3s ease-in-out infinite;
}

.nbt-bot-card {
  background: var(--nbt-bg-card);
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 0;
  border: 1px solid var(--nbt-border-gold);
  box-shadow: 0 0 22px rgba(201, 168, 76, 0.08);
  margin-bottom: 36px;
  overflow: hidden;
  contain: layout style;
}

.nbt-bot-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; bottom: 0;
  width: 3px;
  background: linear-gradient(180deg, var(--nbt-gold), var(--nbt-gold-dim));
  box-shadow: 0 0 18px var(--nbt-gold-glow);
}

.nbt-bot-card.blue-bot   { border-color: rgba(0, 191, 255, 0.35); }
.nbt-bot-card.blue-bot::before { background: linear-gradient(180deg, var(--nbt-blue), rgba(0,191,255,0.3)); box-shadow: 0 0 18px var(--nbt-blue-glow); }
.nbt-bot-card.green-bot  { border-color: rgba(0, 232, 122, 0.35); }
.nbt-bot-card.green-bot::before { background: linear-gradient(180deg, var(--nbt-green), rgba(0,232,122,0.3)); box-shadow: 0 0 18px var(--nbt-green-glow); }
.nbt-bot-card.purple-bot { border-color: rgba(155, 109, 255, 0.35); }
.nbt-bot-card.purple-bot::before { background: linear-gradient(180deg, var(--nbt-purple), rgba(155,109,255,0.3)); box-shadow: 0 0 14px rgba(155,109,255,0.4); }
.nbt-bot-card.amber-bot  { border-color: rgba(255, 149, 0, 0.35); }
.nbt-bot-card.amber-bot::before { background: linear-gradient(180deg, var(--nbt-amber), rgba(255,149,0,0.3)); box-shadow: 0 0 14px rgba(255,149,0,0.4); }

.nbt-bot-info { padding: 36px 32px 36px 44px; }

.nbt-bot-badge {
  font-family: var(--nbt-font-mono);
  font-size: 0.68rem;
  letter-spacing: 0.28em;
  color: var(--nbt-gold);
  border: 1px solid var(--nbt-border-gold);
  display: inline-block;
  padding: 4px 12px;
  margin-bottom: 14px;
}
.nbt-bot-card.blue-bot .nbt-bot-badge   { color: var(--nbt-blue);   border-color: rgba(0,191,255,0.35); }
.nbt-bot-card.green-bot .nbt-bot-badge  { color: var(--nbt-green);  border-color: rgba(0,232,122,0.35); }
.nbt-bot-card.purple-bot .nbt-bot-badge { color: var(--nbt-purple); border-color: rgba(155,109,255,0.35); }
.nbt-bot-card.amber-bot .nbt-bot-badge  { color: var(--nbt-amber);  border-color: rgba(255,149,0,0.35); }

.nbt-bot-name {
  font-size: 1.5rem;
  color: var(--nbt-gold-bright);
  text-shadow: 0 0 10px var(--nbt-gold-glow);
  margin-bottom: 6px;
}
.nbt-bot-card.blue-bot .nbt-bot-name   { color: var(--nbt-blue);   text-shadow: 0 0 10px var(--nbt-blue-glow); }
.nbt-bot-card.green-bot .nbt-bot-name  { color: var(--nbt-green);  text-shadow: 0 0 10px var(--nbt-green-glow); }
.nbt-bot-card.purple-bot .nbt-bot-name { color: var(--nbt-purple); text-shadow: 0 0 10px rgba(155,109,255,0.5); }
.nbt-bot-card.amber-bot .nbt-bot-name  { color: var(--nbt-amber);  text-shadow: 0 0 10px rgba(255,149,0,0.5); }

.nbt-bot-tagline {
  font-size: 0.88rem;
  color: var(--nbt-text-faint);
  letter-spacing: 0.16em;
  font-family: var(--nbt-font-mono);
  margin-bottom: 18px;
}

.nbt-bot-desc { color: var(--nbt-text-dim); font-size: 1rem; line-height: 1.75; margin-bottom: 22px; }

.nbt-bot-features { list-style: none; display: flex; flex-direction: column; gap: 8px; }
.nbt-bot-features li { font-size: 0.93rem; color: var(--nbt-text-dim); display: flex; align-items: flex-start; gap: 10px; }
.nbt-bot-features li::before { content: '▶'; color: var(--nbt-gold); font-size: 0.6rem; margin-top: 5px; flex-shrink: 0; }
.nbt-bot-card.blue-bot .nbt-bot-features li::before   { color: var(--nbt-blue); }
.nbt-bot-card.green-bot .nbt-bot-features li::before  { color: var(--nbt-green); }
.nbt-bot-card.purple-bot .nbt-bot-features li::before { color: var(--nbt-purple); }
.nbt-bot-card.amber-bot .nbt-bot-features li::before  { color: var(--nbt-amber); }

.nbt-bot-stats {
  background: rgba(7, 8, 12, 0.6);
  border-left: 1px solid var(--nbt-border-faint);
  padding: 36px 32px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  justify-content: center;
}

.nbt-bot-stat {
  text-align: center;
  padding: 18px 12px;
  background: rgba(12, 14, 20, 0.6);
  border: 1px solid var(--nbt-border-faint);
}

.nbt-bot-stat-val {
  font-family: var(--nbt-font-mono);
  font-size: 1.9rem;
  color: var(--nbt-gold-bright);
  text-shadow: 0 0 12px var(--nbt-gold-glow);
}
.nbt-bot-card.blue-bot .nbt-bot-stat-val   { color: var(--nbt-blue);   text-shadow: 0 0 12px var(--nbt-blue-glow); }
.nbt-bot-card.green-bot .nbt-bot-stat-val  { color: var(--nbt-green);  text-shadow: 0 0 12px var(--nbt-green-glow); }
.nbt-bot-card.purple-bot .nbt-bot-stat-val { color: var(--nbt-purple); text-shadow: 0 0 12px rgba(155,109,255,0.4); }
.nbt-bot-card.amber-bot .nbt-bot-stat-val  { color: var(--nbt-amber);  text-shadow: 0 0 12px rgba(255,149,0,0.4); }

.nbt-bot-stat-lbl {
  font-size: 0.72rem;
  color: var(--nbt-text-faint);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-top: 6px;
  font-family: var(--nbt-font-mono);
}

/* Coming Soon / Future bot grid */
.nbt-future-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  margin-top: 28px;
}

.nbt-future-card {
  background: var(--nbt-bg-card);
  border: 1px solid rgba(201, 168, 76, 0.12);
  padding: 24px;
  position: relative;
  overflow: hidden;
  opacity: 0.72;
  transition: opacity 0.25s ease, box-shadow 0.25s ease;
  contain: layout style;
}
.nbt-future-card:hover { opacity: 0.92; box-shadow: 0 0 20px rgba(201, 168, 76, 0.1); }
.nbt-future-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(201, 168, 76, 0.25), transparent);
}

.nbt-future-status {
  font-family: var(--nbt-font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.25em;
  color: var(--nbt-text-faint);
  border: 1px solid var(--nbt-border-faint);
  display: inline-block;
  padding: 3px 10px;
  margin-bottom: 10px;
}

.nbt-future-name { color: var(--nbt-text-dim); font-size: 1.05rem; letter-spacing: 0.08em; margin-bottom: 8px; }
.nbt-future-desc { color: var(--nbt-text-faint); font-size: 0.9rem; line-height: 1.6; }

/* Live status dot */
.nbt-live-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--nbt-green);
  box-shadow: 0 0 6px var(--nbt-green-glow);
  margin-right: 8px;
  animation: nbt-pulse-dot 2.5s ease-in-out infinite;
}

/* ============================================================
   COMMUNITY PAGE
   ============================================================ */
.nbt-comm-hero-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  gap: 36px;
  margin-top: 36px;
  align-items: start;
}

.nbt-discord-card {
  background: linear-gradient(135deg, rgba(88, 101, 242, 0.12), rgba(88, 101, 242, 0.04));
  border: 1px solid rgba(88, 101, 242, 0.35);
  padding: 36px;
  position: relative;
  overflow: hidden;
}
.nbt-discord-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, #5865F2, transparent); }

.nbt-testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin-top: 32px;
}

.nbt-testi-card {
  background: var(--nbt-bg-card);
  border: 1px solid var(--nbt-border-faint);
  padding: 24px;
  position: relative;
}
.nbt-testi-card::before { content: '"'; position: absolute; top: 12px; right: 18px; font-family: Georgia, serif; font-size: 3rem; color: rgba(201, 168, 76, 0.12); line-height: 1; }
.nbt-testi-text { color: var(--nbt-text-dim); font-size: 0.93rem; line-height: 1.7; margin-bottom: 16px; font-style: italic; }
.nbt-testi-name { color: var(--nbt-gold); font-family: var(--nbt-font-mono); font-size: 0.75rem; letter-spacing: 0.18em; }
.nbt-testi-role { color: var(--nbt-text-faint); font-size: 0.75rem; letter-spacing: 0.12em; }

/* ============================================================
   PERFORMANCE TERMINAL
   ============================================================ */
.nbt-terminal-header {
  background: rgba(7, 8, 12, 0.95);
  border: 1px solid var(--nbt-border-gold);
  border-bottom: 2px solid var(--nbt-gold);
  padding: 14px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 24px;
  box-shadow: 0 0 28px rgba(201, 168, 76, 0.15);
}

.nbt-terminal-title {
  font-family: var(--nbt-font-mono);
  font-size: 0.88rem;
  letter-spacing: 0.28em;
  color: var(--nbt-gold-bright);
  text-shadow: 0 0 8px var(--nbt-gold-glow);
}

.nbt-perf-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.nbt-perf-panel {
  background: var(--nbt-bg-card);
  border: 1px solid var(--nbt-border-gold);
  padding: 24px;
  position: relative;
}
.nbt-perf-panel::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--nbt-gold), transparent); }

.nbt-perf-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--nbt-bg-card);
  border: 1px solid var(--nbt-border-gold);
  margin-top: 24px;
}
.nbt-perf-table th, .nbt-perf-table td {
  padding: 11px 16px;
  text-align: left;
  border-bottom: 1px solid var(--nbt-border-faint);
  font-family: var(--nbt-font-mono);
  font-size: 0.8rem;
  letter-spacing: 0.06em;
}
.nbt-perf-table th {
  background: rgba(201, 168, 76, 0.07);
  color: var(--nbt-gold);
  font-size: 0.68rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-shadow: 0 0 6px var(--nbt-gold-glow);
}
.nbt-perf-table .up { color: var(--nbt-green); text-shadow: 0 0 4px var(--nbt-green-glow); }
.nbt-perf-table .dn { color: var(--nbt-red);   text-shadow: 0 0 4px var(--nbt-red-glow); }
.nbt-perf-table tr:last-child td { border-bottom: none; }

/* ============================================================
   ABOUT / TEAM PAGE
   ============================================================ */
.nbt-mission-block {
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.06), rgba(0, 191, 255, 0.03));
  border: 1px solid var(--nbt-border-gold);
  border-left: 4px solid var(--nbt-gold);
  padding: 36px 40px;
  margin-bottom: 56px;
  box-shadow: 0 0 28px rgba(201, 168, 76, 0.08);
}

.nbt-team-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
  max-width: 860px;
}

.nbt-team-card {
  background: var(--nbt-bg-card);
  border: 1px solid var(--nbt-border-gold);
  padding: 32px;
  display: flex;
  gap: 24px;
  align-items: flex-start;
  position: relative;
  overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
  contain: layout style;
}
.nbt-team-card:hover { transform: translateY(-2px); box-shadow: 0 0 32px rgba(201, 168, 76, 0.15); }
.nbt-team-card::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--nbt-gold), transparent); }

.nbt-avatar {
  width: 76px;
  height: 76px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 2px solid var(--nbt-gold);
  box-shadow: 0 0 18px rgba(201, 168, 76, 0.4);
  object-fit: cover;
}

.nbt-avatar-placeholder {
  width: 76px;
  height: 76px;
  border-radius: 50%;
  flex-shrink: 0;
  border: 2px solid var(--nbt-gold);
  box-shadow: 0 0 18px rgba(201, 168, 76, 0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--nbt-font-display);
  font-weight: 900;
  font-size: 1.5rem;
  color: var(--nbt-gold-bright);
  background: radial-gradient(circle, rgba(201, 168, 76, 0.15), rgba(7, 8, 12, 0.9));
  text-shadow: 0 0 10px var(--nbt-gold-glow);
}

.nbt-team-name  { color: var(--nbt-gold-bright); font-size: 1.15rem; letter-spacing: 0.1em; text-shadow: 0 0 8px var(--nbt-gold-glow); margin-bottom: 4px; }
.nbt-team-title { font-family: var(--nbt-font-mono); font-size: 0.72rem; letter-spacing: 0.22em; color: var(--nbt-gold-dim); text-transform: uppercase; margin-bottom: 12px; }
.nbt-team-bio   { color: var(--nbt-text-dim); font-size: 0.92rem; line-height: 1.7; }

/* ============================================================
   FOOTER
   ============================================================ */
.nbt-footer {
  background: rgba(7, 8, 12, 0.98);
  border-top: 1px solid var(--nbt-border-gold);
  color: var(--nbt-text-faint);
}

.nbt-footer-inner {
  max-width: var(--nbt-max-w);
  margin: 0 auto;
  padding: 48px 32px 32px;
}

.nbt-footer-top {
  display: grid;
  grid-template-columns: 1.2fr 1fr 1fr;
  gap: 48px;
  margin-bottom: 40px;
}

.nbt-footer-brand {}

.nbt-footer-logo {
  font-family: var(--nbt-font-display) !important;
  font-weight: 900;
  font-size: 1.3rem;
  background: linear-gradient(90deg, #7A6428, #C9A84C 40%, #F5D155 55%, #C9A84C 70%, #7A6428);
  background-size: 200%;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: nbt-gold-shine 5s linear infinite;
  display: inline-block;
  margin-bottom: 6px;
  will-change: background-position;
}

.nbt-footer-tagline {
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.68rem;
  color: var(--nbt-text-faint);
  letter-spacing: 0.22em;
  margin-bottom: 20px;
  display: block;
}

.nbt-footer-contact {
  font-family: var(--nbt-font-mono);
  font-size: 0.7rem;
  color: var(--nbt-text-faint);
  letter-spacing: 0.1em;
  line-height: 1.9;
}
.nbt-footer-contact a {
  color: var(--nbt-text-faint);
  transition: color 0.2s;
}
.nbt-footer-contact a:hover { color: var(--nbt-gold); }

.nbt-footer-col-title {
  font-family: var(--nbt-font-mono);
  font-size: 0.65rem;
  letter-spacing: 0.28em;
  color: var(--nbt-gold-dim);
  text-transform: uppercase;
  margin-bottom: 16px;
  border-bottom: 1px solid var(--nbt-border-faint);
  padding-bottom: 8px;
}

/* Footer nav from wp_nav_menu */
.nbt-footer-nav ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.nbt-footer-nav ul li a {
  font-family: var(--nbt-font-mono);
  font-size: 0.7rem;
  color: var(--nbt-text-faint);
  letter-spacing: 0.18em;
  transition: color 0.2s;
}
.nbt-footer-nav ul li a:hover { color: var(--nbt-gold); }

/* Social icons row */
.nbt-social-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}

.nbt-social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--nbt-border-faint);
  color: var(--nbt-text-faint);
  font-family: var(--nbt-font-mono);
  font-size: 0.75rem;
  letter-spacing: 0.05em;
  transition: all 0.22s ease;
  text-decoration: none;
}
.nbt-social-link:hover {
  border-color: var(--nbt-gold);
  color: var(--nbt-gold);
  box-shadow: 0 0 12px rgba(201, 168, 76, 0.2);
}

/* Footer bottom bar */
.nbt-footer-bottom {
  border-top: 1px solid var(--nbt-border-faint);
  padding-top: 24px;
}

.nbt-footer-legal-row {
  display: flex;
  gap: 24px;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 20px;
}

.nbt-footer-legal-row a {
  font-family: var(--nbt-font-mono);
  font-size: 0.65rem;
  color: var(--nbt-text-faint);
  letter-spacing: 0.18em;
  transition: color 0.2s;
  text-decoration: none;
}
.nbt-footer-legal-row a:hover { color: var(--nbt-gold); }

.nbt-footer-disc {
  font-family: var(--nbt-font-mono);
  font-size: 0.62rem;
  color: var(--nbt-text-faint);
  max-width: 880px;
  margin: 0 auto 20px;
  line-height: 1.75;
  letter-spacing: 0.04em;
  text-align: center;
}

.nbt-footer-copy {
  font-family: var(--nbt-font-mono);
  font-size: 0.65rem;
  color: var(--nbt-text-faint);
  letter-spacing: 0.16em;
  text-align: center;
}

/* ============================================================
   MINIORANGE SOCIAL LOGIN — POPUP RESKIN
   ============================================================ */
.mo-social-login-section,
.elementor-popup-modal .elementor-popup-modal__overlay {
  background: rgba(7, 8, 12, 0.96) !important;
}

.mo-social-login-section .mo-login-popup {
  background: var(--nbt-bg-card) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  box-shadow: 0 0 60px rgba(201, 168, 76, 0.18), inset 0 0 40px rgba(201, 168, 76, 0.04) !important;
}

.mo_social_login_ul, .mo-social-login-ul {
  list-style: none !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

.mo_social_login_ul li a, .mo-social-login-ul li a {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  padding: 12px 20px !important;
  background: rgba(201, 168, 76, 0.06) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  color: var(--nbt-text-dim) !important;
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.14em !important;
  text-decoration: none !important;
  transition: all 0.22s ease !important;
}

.mo_social_login_ul li a:hover, .mo-social-login-ul li a:hover {
  background: rgba(201, 168, 76, 0.15) !important;
  border-color: var(--nbt-gold) !important;
  color: var(--nbt-gold-bright) !important;
}

/* ============================================================
   WOOCOMMERCE DARK THEME
   ============================================================ */
body.woocommerce, body.woocommerce-page,
body.post-type-archive-product, body.tax-product_cat {
  background-color: var(--nbt-bg-base) !important;
}

.woocommerce-breadcrumb {
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.72rem !important;
  color: var(--nbt-text-faint) !important;
  letter-spacing: 0.14em !important;
}
.woocommerce-breadcrumb a { color: var(--nbt-gold-dim) !important; }
.woocommerce-breadcrumb a:hover { color: var(--nbt-gold) !important; }

.woocommerce-result-count {
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.72rem !important;
  color: var(--nbt-text-faint) !important;
}

.woocommerce-ordering select {
  background: var(--nbt-bg-card) !important;
  color: var(--nbt-text-dim) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.75rem !important;
  padding: 8px 12px !important;
  outline: none !important;
}

.woocommerce ul.products {
  display: grid !important;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)) !important;
  gap: 20px !important;
}

.woocommerce ul.products li.product {
  background: var(--nbt-bg-card) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  padding: 0 !important;
  position: relative !important;
  overflow: hidden !important;
  transition: transform 0.25s ease, box-shadow 0.25s ease !important;
}

.woocommerce ul.products li.product::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--nbt-gold), transparent);
  z-index: 1;
}

.woocommerce ul.products li.product:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 0 28px rgba(201, 168, 76, 0.2) !important;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce ul.products li.product h2 {
  font-family: var(--nbt-font-display) !important;
  font-size: 0.88rem !important;
  color: var(--nbt-text) !important;
  letter-spacing: 0.08em !important;
  padding: 14px 16px 4px !important;
  margin: 0 !important;
}

.woocommerce ul.products li.product .price {
  font-family: var(--nbt-font-mono) !important;
  color: var(--nbt-gold-bright) !important;
  font-size: 1rem !important;
  text-shadow: 0 0 6px var(--nbt-gold-glow) !important;
  padding: 0 16px 6px !important;
  display: block !important;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button {
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.18), rgba(201, 168, 76, 0.06)) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  color: var(--nbt-gold-bright) !important;
  font-family: var(--nbt-font-display) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  padding: 10px 16px !important;
  width: calc(100% - 32px) !important;
  margin: 8px 16px 16px !important;
  display: block !important;
  text-align: center !important;
  transition: all 0.25s ease !important;
  border-radius: 0 !important;
}

.woocommerce ul.products li.product .button:hover {
  background: rgba(201, 168, 76, 0.28) !important;
  box-shadow: 0 0 18px rgba(201, 168, 76, 0.3) !important;
}

.woocommerce div.product .product_title {
  font-family: var(--nbt-font-display) !important;
  color: var(--nbt-gold-bright) !important;
  text-shadow: 0 0 18px var(--nbt-gold-glow) !important;
}

.woocommerce div.product .price {
  font-family: var(--nbt-font-mono) !important;
  color: var(--nbt-gold-bright) !important;
  font-size: 1.5rem !important;
  text-shadow: 0 0 8px var(--nbt-gold-glow) !important;
}

.woocommerce .single_add_to_cart_button,
.woocommerce #respond input#submit,
.woocommerce a.button,
.woocommerce button.button {
  background: linear-gradient(135deg, rgba(201, 168, 76, 0.22), rgba(201, 168, 76, 0.08)) !important;
  border: 1px solid var(--nbt-gold) !important;
  color: var(--nbt-gold-bright) !important;
  font-family: var(--nbt-font-display) !important;
  font-size: 0.82rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  padding: 14px 32px !important;
  border-radius: 0 !important;
  transition: all 0.25s ease !important;
  box-shadow: 0 0 18px rgba(201, 168, 76, 0.15) !important;
}

.woocommerce .single_add_to_cart_button:hover,
.woocommerce a.button:hover,
.woocommerce button.button:hover {
  background: rgba(201, 168, 76, 0.32) !important;
  box-shadow: 0 0 32px rgba(201, 168, 76, 0.35) !important;
  transform: translateY(-1px) !important;
}

.woocommerce form .form-row input,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select {
  background: var(--nbt-bg-card) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  color: var(--nbt-text) !important;
  font-family: var(--nbt-font-body) !important;
  padding: 12px 16px !important;
  border-radius: 0 !important;
}

.woocommerce form .form-row input:focus,
.woocommerce form .form-row textarea:focus {
  border-color: var(--nbt-gold) !important;
  box-shadow: 0 0 14px rgba(201, 168, 76, 0.2) !important;
  outline: none !important;
}

.woocommerce form .form-row label {
  color: var(--nbt-gold-dim) !important;
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
}

.woocommerce-message, .woocommerce-info {
  background: rgba(201, 168, 76, 0.08) !important;
  border-top-color: var(--nbt-gold) !important;
  color: var(--nbt-text-dim) !important;
}

.woocommerce-error {
  background: rgba(255, 59, 48, 0.08) !important;
  border-top-color: var(--nbt-red) !important;
  color: var(--nbt-red) !important;
}

.woocommerce-cart table.cart th {
  background: rgba(201, 168, 76, 0.07) !important;
  color: var(--nbt-gold) !important;
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.72rem !important;
  letter-spacing: 0.18em !important;
  text-transform: uppercase !important;
  border-bottom: 1px solid var(--nbt-border-gold) !important;
}

.woocommerce-cart table.cart td {
  background: var(--nbt-bg-card) !important;
  color: var(--nbt-text-dim) !important;
  border-bottom: 1px solid var(--nbt-border-faint) !important;
}

.woocommerce-MyAccount-navigation ul { list-style: none !important; padding: 0 !important; }
.woocommerce-MyAccount-navigation ul li a {
  display: block !important;
  padding: 10px 16px !important;
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.78rem !important;
  color: var(--nbt-text-dim) !important;
  border-left: 2px solid transparent !important;
  transition: all 0.2s !important;
}
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a {
  color: var(--nbt-gold-bright) !important;
  border-left-color: var(--nbt-gold) !important;
  background: rgba(201, 168, 76, 0.06) !important;
}

/* ============================================================
   WPDATATABLES — BLOOMBERG TERMINAL DARK THEME
   ============================================================ */
.wpDataTablesWrapper {
  background: var(--nbt-bg-card) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  padding: 0 !important;
  box-shadow: 0 0 28px rgba(201, 168, 76, 0.1) !important;
  position: relative !important;
}

.wpDataTablesWrapper::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg, transparent, var(--nbt-gold), transparent);
}

.wpDataTablesWrapper .dataTables_length label,
.wpDataTablesWrapper .dataTables_filter label {
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.7rem !important;
  color: var(--nbt-text-faint) !important;
  letter-spacing: 0.14em !important;
}

.wpDataTablesWrapper .dataTables_filter input {
  background: var(--nbt-bg-base) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  color: var(--nbt-text) !important;
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.78rem !important;
  padding: 6px 12px !important;
  outline: none !important;
}

.wpdtSimpleTable, table.wpDataTable {
  width: 100% !important;
  border-collapse: collapse !important;
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.82rem !important;
}

.wpdtSimpleTable th, table.wpDataTable th {
  background: rgba(201, 168, 76, 0.09) !important;
  color: var(--nbt-gold) !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.22em !important;
  text-transform: uppercase !important;
  padding: 12px 16px !important;
  border-bottom: 1px solid var(--nbt-border-gold) !important;
  text-shadow: 0 0 6px var(--nbt-gold-glow) !important;
  white-space: nowrap !important;
}

.wpdtSimpleTable td, table.wpDataTable td {
  padding: 10px 16px !important;
  border-bottom: 1px solid var(--nbt-border-faint) !important;
  color: var(--nbt-text-dim) !important;
  background: var(--nbt-bg-card) !important;
}

table.wpDataTable tr:nth-child(even) td { background: rgba(255, 255, 255, 0.02) !important; }
table.wpDataTable tr:hover td { background: rgba(201, 168, 76, 0.04) !important; }

.wpdtSimpleTable td.nbt-win, table.wpDataTable td.nbt-win { color: var(--nbt-green) !important; text-shadow: 0 0 4px var(--nbt-green-glow) !important; }
.wpdtSimpleTable td.nbt-loss, table.wpDataTable td.nbt-loss { color: var(--nbt-red) !important; text-shadow: 0 0 4px var(--nbt-red-glow) !important; }

.wpDataTablesWrapper .dataTables_paginate .paginate_button {
  background: var(--nbt-bg-card) !important;
  border: 1px solid var(--nbt-border-faint) !important;
  color: var(--nbt-text-dim) !important;
  font-family: var(--nbt-font-mono) !important;
  font-size: 0.72rem !important;
  padding: 6px 12px !important;
  transition: all 0.2s !important;
}

.wpDataTablesWrapper .dataTables_paginate .paginate_button.current,
.wpDataTablesWrapper .dataTables_paginate .paginate_button:hover {
  background: rgba(201, 168, 76, 0.12) !important;
  border-color: var(--nbt-gold) !important;
  color: var(--nbt-gold-bright) !important;
}

/* ============================================================
   TUTOR LMS — DARK THEME
   ============================================================ */
body.tutor-dashboard-page, body.tutor-page-content,
body.single-courses, body.single-tutor_quiz,
body.single-lesson, body.single-tutor_assignments,
body.archive.tax-course-category, body.post-type-archive-courses {
  background-color: var(--nbt-bg-base) !important;
  color: var(--nbt-text) !important;
}

.tutor-wrap, .tutor-container, .tutor-page-wrap,
.tutor-page-content, .tutor-dashboard, .tutor-dashboard-content {
  background-color: var(--nbt-bg-base) !important;
  color: var(--nbt-text) !important;
  font-family: var(--nbt-font-body) !important;
}

[class*="tutor-"] p, [class*="tutor-"] li,
[class*="tutor-"] span:not([class*="tutor-icon"]),
[class*="tutor-"] label { color: var(--nbt-text) !important; font-family: var(--nbt-font-body) !important; }

[class*="tutor-"] h1, [class*="tutor-"] h2,
[class*="tutor-"] h3, [class*="tutor-"] h4 {
  font-family: var(--nbt-font-display) !important;
  color: var(--nbt-text) !important;
}

[class*="tutor-"] a { color: var(--nbt-gold) !important; }
[class*="tutor-"] a:hover { color: var(--nbt-gold-bright) !important; }

.tutor-course-list-item, .tutor-course-loop,
.tutor-course-card, .tutor-course {
  background: var(--nbt-bg-card) !important;
  border: 1px solid var(--nbt-border-gold) !important;
  border-radius: 0 !important;
  box-shadow: 0 0 18px rgba(201, 168, 76, 0.08) !important;
}

/* ============================================================
   HUB / MEMBER PORTAL
   ============================================================ */
.nbt-hub-wrap { background: var(--nbt-bg-base) !important; }

iframe[src*="discord"] {
  border: 1px solid rgba(88, 101, 242, 0.35) !important;
}

iframe[src*="substack"] {
  border: 1px solid var(--nbt-border-gold) !important;
}

/* Fade-in animation for scroll reveals */
.nbt-fade-in {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.nbt-fade-in.nbt-visible {
  opacity: 1;
  transform: translateY(0);
}

/* ============================================================
   ANIMATIONS / KEYFRAMES
   ============================================================ */
@keyframes nbt-gold-shine {
  0%   { background-position: 0%; }
  100% { background-position: 200%; }
}

@keyframes nbt-ticker-scroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

@keyframes nbt-glow-pulse {
  0%, 100% { opacity: 0; }
  50%       { opacity: 0.6; }
}

@keyframes nbt-scan-h {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

@keyframes nbt-flicker {
  0%, 95%, 100% { opacity: 1; }
  97%           { opacity: 0.7; }
  99%           { opacity: 0.6; }
}

@keyframes nbt-float {
  0%, 100% { transform: translateY(0); }
  50%       { transform: translateY(-8px); }
}

@keyframes nbt-pulse-dot {
  0%, 100% { transform: scale(1);   opacity: 1; }
  50%       { transform: scale(1.3); opacity: 0.7; }
}

/* Compat aliases for unprefixed keyframe names used in inline template styles */
@keyframes pulse-dot {
  0%, 100% { transform: scale(1);   opacity: 1; }
  50%       { transform: scale(1.3); opacity: 0.7; }
}
@keyframes gold-shine {
  0%   { background-position: 0%; }
  100% { background-position: 200%; }
}

/* ============================================================
   MISSING COMPONENT RULES — added post-audit
   ============================================================ */

/* Terminal indicators (Performance page) */
.nbt-terminal-indicators { display:flex;gap:20px;align-items:center; }
.nbt-t-ind { font-family:var(--nbt-font-mono);font-size:.72rem;letter-spacing:.14em;display:flex;flex-direction:column;align-items:flex-end; }
.nbt-t-ind .lbl { color:var(--nbt-text-faint);font-size:.62rem; }
.nbt-t-ind .val { color:var(--nbt-green);text-shadow:0 0 6px var(--nbt-green-glow); }
.nbt-t-ind .val.dn { color:var(--nbt-red);text-shadow:0 0 6px var(--nbt-red-glow); }

/* Perf panel title */
.nbt-perf-panel-title { font-family:var(--nbt-font-mono);color:var(--nbt-gold);font-size:.75rem;letter-spacing:.22em;text-transform:uppercase;margin-bottom:20px;text-shadow:0 0 6px var(--nbt-gold-glow); }

/* Chart container */
.nbt-chart-container { position:relative;height:260px; }

/* Monthly heatmap */
.nbt-heatmap { display:grid;grid-template-columns:repeat(12,1fr);gap:4px;margin-top:16px; }
.nbt-hm-cell { padding:8px 4px;text-align:center;font-family:var(--nbt-font-mono);font-size:.68rem;letter-spacing:.04em;border:1px solid rgba(255,255,255,0.04); }
.nbt-hm-cell.pos { background:rgba(0,232,122,0.15);color:var(--nbt-green); }
.nbt-hm-cell.neg { background:rgba(255,59,48,0.15);color:var(--nbt-red); }
.nbt-hm-cell.flat { background:rgba(201,168,76,0.08);color:var(--nbt-text-faint); }

/* Pillar icon */
.nbt-pillar-icon { font-size:2rem;margin-bottom:16px;display:block; }

/* Partners row */
.nbt-partners-row { display:flex;gap:32px;align-items:center;flex-wrap:wrap;justify-content:center;margin-top:28px; }
.nbt-partner-badge { font-family:var(--nbt-font-mono);font-size:.75rem;letter-spacing:.2em;color:var(--nbt-text-faint);padding:10px 22px;border:1px solid rgba(201,168,76,0.12);transition:all .25s; }
.nbt-partner-badge:hover { color:var(--nbt-gold-dim);border-color:var(--nbt-border-gold); }

/* Values grid (About page) */
.nbt-values-grid { display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:28px; }
.nbt-value-card { background:var(--nbt-bg-card);border:1px solid var(--nbt-border-faint);padding:22px 18px;text-align:center;transition:border-color .25s,box-shadow .25s; }
.nbt-value-card:hover { border-color:var(--nbt-border-gold);box-shadow:0 0 18px rgba(201,168,76,0.1); }
.nbt-value-icon { font-size:1.6rem;margin-bottom:10px;display:block; }
.nbt-value-name { color:var(--nbt-gold);font-size:.92rem;letter-spacing:.12em;margin-bottom:6px; }
.nbt-value-desc { color:var(--nbt-text-faint);font-size:.84rem;line-height:1.6; }

/* Mission block (About page) */
.nbt-mission-attr { margin-top:16px;font-family:var(--nbt-font-mono);font-size:.73rem;color:var(--nbt-text-faint);letter-spacing:.2em; }

/* Discord card inner content (Community page) */
.nbt-discord-icon { font-size:2.5rem;margin-bottom:16px;display:block; }
.nbt-discord-name { color:#7289DA;font-size:1.3rem;letter-spacing:.1em;text-shadow:0 0 12px rgba(114,137,218,0.5);margin-bottom:10px; }
.nbt-discord-desc { color:var(--nbt-text-dim);font-size:1rem;line-height:1.7;margin-bottom:22px; }
.nbt-discord-stats { display:flex;gap:28px;margin-bottom:24px; }
.nbt-discord-stat { text-align:center; }
.nbt-discord-stat .v { font-family:var(--nbt-font-mono);font-size:1.4rem;color:var(--nbt-gold-bright);text-shadow:0 0 8px var(--nbt-gold-glow); }
.nbt-discord-stat .l { font-size:.72rem;color:var(--nbt-text-faint);letter-spacing:.18em;text-transform:uppercase; }

/* Resource cards (Community page) */
.nbt-comm-side { display:flex;flex-direction:column;gap:20px; }
.nbt-resource-card { background:var(--nbt-bg-card);border:1px solid var(--nbt-border-gold);padding:22px;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s; }
.nbt-resource-card:hover { transform:translateX(3px);box-shadow:0 0 20px rgba(201,168,76,0.12); }
.nbt-resource-card::before { content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--nbt-gold); }
.nbt-resource-title { color:var(--nbt-gold-bright);font-size:.95rem;letter-spacing:.1em;margin-bottom:6px; }
.nbt-resource-desc { color:var(--nbt-text-dim);font-size:.9rem; }

/* Live dot animation (Division page) */
.nbt-live-dot { display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--nbt-green);box-shadow:0 0 8px var(--nbt-green-glow);animation:nbt-pulse-dot 2s ease-in-out infinite; }

/* Responsive additions */
@media (max-width:768px) {
  .nbt-values-grid { grid-template-columns:repeat(2,1fr); }
  .nbt-heatmap { grid-template-columns:repeat(6,1fr); }
  .nbt-partners-row { gap:16px; }
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
  .nbt-ticker-track { animation-duration: 200s; }
  .nbt-logo-text, .nbt-footer-logo { animation: none; background-position: 50%; }
  .nbt-hero-pretitle { animation: none; }
  .nbt-stat-card::after { animation: none; opacity: 0; }
  .nbt-stat-card::before { animation: none; }
  .nbt-live-dot { animation: none; }
  .nbt-ai-class-badge::before { animation: none; }
  * { transition-duration: 0.01ms !important; animation-duration: 0.01ms !important; }
}

/* ============================================================
   RESPONSIVE — DESKTOP >1024
   ============================================================ */
@media (min-width: 1025px) {
  .nbt-nav-toggle { display: none !important; }
}

/* ============================================================
   RESPONSIVE — TABLET 768–1024
   ============================================================ */
@media (max-width: 1024px) {
  .nbt-bot-card { grid-template-columns: 1fr; }
  .nbt-bot-stats { border-left: none; border-top: 1px solid var(--nbt-border-faint); flex-direction: row; flex-wrap: wrap; justify-content: center; }
  .nbt-future-grid { grid-template-columns: 1fr; }
  .nbt-perf-grid { grid-template-columns: 1fr; }
  .nbt-footer-top { grid-template-columns: 1fr 1fr; gap: 32px; }
  .nbt-footer-top > .nbt-footer-brand { grid-column: 1 / -1; }

  .nbt-primary-nav ul li ul { left: auto; right: 0; }
}

/* ============================================================
   RESPONSIVE — MOBILE <768
   ============================================================ */
@media (max-width: 768px) {
  :root {
    --nbt-section-pad: 60px 20px;
  }

  .nbt-navbar { padding: 0 16px; }
  .nbt-nav-toggle { display: flex; }

  /* Mobile nav — hidden until toggled */
  .nbt-primary-nav {
    display: none;
    position: absolute;
    top: 64px;
    left: 0;
    right: 0;
    background: rgba(7, 8, 12, 0.97);
    border-bottom: 1px solid var(--nbt-border-gold);
    padding: 12px 0;
    z-index: 9999;
    flex-direction: column;
    align-items: flex-start;
  }
  .nbt-primary-nav.mobile-open {
    display: flex;
  }
  .nbt-primary-nav ul {
    flex-direction: column;
    width: 100%;
    gap: 0;
  }
  .nbt-primary-nav ul li a {
    width: 100%;
    text-align: center;
    padding: 12px 20px !important;
  }
  .nbt-primary-nav ul li ul {
    position: static;
    display: none;
    width: 100%;
    border: none;
    border-top: 1px solid var(--nbt-border-faint);
  }

  .nbt-nav-portal-btn { display: none; }

  .nbt-hero-stats { grid-template-columns: 1fr; }
  .nbt-pillars-grid { grid-template-columns: 1fr; }
  .nbt-comm-hero-grid { grid-template-columns: 1fr; }
  .nbt-testimonials-grid { grid-template-columns: 1fr; }
  .nbt-team-grid { grid-template-columns: 1fr; }
  .nbt-footer-top { grid-template-columns: 1fr; gap: 28px; }
  .nbt-footer-legal-row { gap: 16px; }

  .wpDataTablesWrapper { overflow-x: auto !important; }
  table.wpDataTable { min-width: 600px !important; }
}

/* ============================================================
   WP ADMIN BAR — push fixed header down when admin is logged in
   ============================================================ */
.admin-bar .nbt-ticker-bar { top: 32px; }
.admin-bar .nbt-navbar      { top: 96px; }
.admin-bar .nbt-page-wrap   { padding-top: 160px; }
@media screen and (max-width: 782px) {
  .admin-bar .nbt-ticker-bar { top: 46px; }
  .admin-bar .nbt-navbar      { top: 110px; }
  .admin-bar .nbt-page-wrap   { padding-top: 174px; }
}
