/* ============================================================
   NIGHTHAWK SHARED THEME
   Used by every public + staff page in the Evidence app.
============================================================ */
:root{
  /* ── Brand colors ── */
  --nh-red:#E63946;--nh-red-dark:#A4161A;--nh-red-deeper:#6A040F;
  --nh-pink:#FF6B7A;--nh-pink-soft:#FF8A95;

  /* ── Surfaces ── */
  --nh-bg:#07030A;--nh-panel:#100616;--nh-panel-2:#180A20;--nh-panel-3:#20102A;
  --nh-border:#2E1040;--nh-border-2:#3E1850;

  /* ── Text ── */
  --nh-text:#F0E8F5;--nh-muted:#9B7AAF;--nh-dim:#5A4070;
  --nh-text-bright:#fff;          /* Maximum-contrast text — replaces raw #fff */

  /* ── Semantic ── */
  --nh-blue:#2E75B6;
  --nh-blue-light:#7AB8E8;        /* Lighter blue for info accents */
  --nh-blue-mid:#5da3d8;           /* Mid blue for inline pills */
  --nh-success:#27AE60;
  --nh-success-light:#5fd084;     /* Lighter green for inline pills */
  --nh-warn:#E67E22;
  --nh-warn-light:#f4a261;        /* Lighter orange for inline pills */
  --nh-gold:#FFD700;               /* Owner / privileged accents */

  /* ── Phosphor CRT effect intensity (per-mode tunable)
     The portal has three CRT modes via body.nh-phosphor-{full|light|off}.
     "Full" uses the defaults in tailwind.css (--phosphor-*). The portal-
     specific LIGHT mode tones down each overlay; change these tokens to
     re-tune the LIGHT preset across every page. OFF mode hides all overlays
     so it doesn't have tunable knobs. */
  --nh-phos-light-overlay:0.30;
  --nh-phos-light-grain:0.18;
  --nh-phos-light-field:0.25;
  --nh-phos-light-sweep:0.18;
  --nh-phos-light-sweep-duration:18s;

  /* ── Red alpha tints (canonical 8-step scale)
     Audit found 38 distinct alpha values for the brand red rgba(230,57,70,X)
     used across the codebase. These tokens are the canonical set — pick the
     closest step instead of inventing a new alpha value.
       a05 — barely-there background tint (cards, panels, inactive states)
       a08 — subtle button/control background
       a10 — light tint for inline accents and hovers
       a15 — primary button background base
       a25 — primary button hover background, light border accent
       a40 — semantic border accent on most components
       a55 — focus-ring outline canonical
       a70 — strong glow / active border / shadow component */
  --nh-red-a05:rgba(230,57,70,.05);
  --nh-red-a08:rgba(230,57,70,.08);
  --nh-red-a10:rgba(230,57,70,.10);
  --nh-red-a15:rgba(230,57,70,.15);
  --nh-red-a16:rgba(230,57,70,.16);    /* legacy — alias of a15 for back-compat */
  --nh-red-a25:rgba(230,57,70,.25);
  --nh-red-a32:rgba(230,57,70,.32);    /* legacy — alias of a25/a40 region */
  --nh-red-a40:rgba(230,57,70,.40);
  --nh-red-a55:rgba(230,57,70,.55);
  --nh-red-a70:rgba(230,57,70,.70);

  /* ── Neon glow shadows ── */
  --nh-glow-red:0 0 8px rgba(230,57,70,.8),0 0 24px rgba(230,57,70,.4),0 0 48px rgba(230,57,70,.15);
  --nh-glow-pink:0 0 8px rgba(255,107,122,.7),0 0 20px rgba(255,107,122,.3);
  --nh-glow-sm:0 0 5px rgba(230,57,70,.6),0 0 14px rgba(230,57,70,.25);
  --nh-glow-border:0 0 6px rgba(230,57,70,.5),inset 0 0 6px rgba(230,57,70,.05);

  /* ── Typography ── */
  --nh-font-mono:'JetBrains Mono','SF Mono',Menlo,monospace;
  --nh-font-body:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;

  /* Canonical font-size scale — drops the 11 outlier sizes (9.5/10.5/11.5/12.5/13.5/15/18/24/26/28/54).
     New code should reference these instead of raw pixels. */
  --font-xs:9px;
  --font-sm:10px;
  --font-base:11px;
  --font-md:12px;
  --font-lg:13px;
  --font-xl:14px;
  --font-2xl:16px;
  --font-3xl:22px;
  --font-4xl:32px;

  /* Canonical font-weight scale */
  --fw-normal:400;
  --fw-medium:500;
  --fw-semibold:600;
  --fw-bold:700;
  --fw-extrabold:800;
  --fw-black:900;

  /* ── Spacing scale (4 / 8 base) ── */
  --space-1:4px;
  --space-2:8px;
  --space-3:12px;
  --space-4:16px;
  --space-5:20px;
  --space-6:24px;
  --space-7:32px;
  --space-8:48px;

  /* ── Border radius scale ── */
  --radius-sm:4px;
  --radius-md:8px;
  --radius-lg:10px;
  --radius-xl:12px;
  --radius-pill:999px;
  --radius-full:50%;

  /* ── Motion ── */
  --motion-fast:.12s;
  --motion-base:.18s;
  --motion-slow:.28s;
  --ease-out:cubic-bezier(.25,.8,.25,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100%;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--nh-bg);color:var(--nh-text);font-size:14px;line-height:1.5}

/* Body — dark grid + scanline */
body{
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(230,57,70,.018) 2px,rgba(230,57,70,.018) 3px),
    repeating-linear-gradient(90deg,transparent,transparent 40px,rgba(100,0,150,.04) 40px,rgba(100,0,150,.04) 41px),
    repeating-linear-gradient(-45deg,transparent 0,transparent 14px,rgba(230,57,70,.01) 14px,rgba(230,57,70,.01) 15px),
    radial-gradient(ellipse at top left,rgba(100,0,150,.12) 0%,transparent 55%),
    radial-gradient(ellipse at bottom right,rgba(164,22,26,.08) 0%,transparent 55%);
  background-attachment:fixed;
  display:flex;flex-direction:column;min-height:100vh;
}
a{color:var(--nh-pink);text-decoration:none}
a:hover{color:var(--nh-pink-soft)}
button{cursor:pointer;font-family:inherit;border:none;color:inherit}

/* === BANNER === */
.nh-banner{
  position:relative;height:170px;
  background:linear-gradient(120deg,var(--nh-red-deeper) 0%,var(--nh-panel-2) 55%,var(--nh-bg) 100%);
  overflow:hidden;display:flex;align-items:center;justify-content:flex-end;
  padding:0 50px;
  border-top:1px solid rgba(230,57,70,.4);
  border-bottom:2px solid var(--nh-red);
  box-shadow:0 2px 30px rgba(230,57,70,.25),0 4px 60px rgba(230,57,70,.1);
  z-index:5;
}
/* Diagonal hatch */
.nh-banner::before{content:'';position:absolute;inset:0;background-image:repeating-linear-gradient(-45deg,transparent 0,transparent 6px,rgba(230,57,70,.04) 6px,rgba(230,57,70,.04) 7px)}
/* Scanlines */
.nh-banner::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:repeating-linear-gradient(0deg,transparent,transparent 3px,rgba(0,0,0,.18) 3px,rgba(0,0,0,.18) 4px);
  z-index:8;
}
/* Left glow blob */
.nh-banner-glow{position:absolute;left:0;top:0;bottom:0;width:50%;background:radial-gradient(ellipse at left center,rgba(164,22,26,.5) 0%,transparent 70%);z-index:1}

.nh-corner{position:absolute;width:26px;height:26px;border:2px solid var(--nh-red);z-index:10;
  filter:drop-shadow(0 0 4px rgba(230,57,70,.8)) drop-shadow(0 0 12px rgba(230,57,70,.4))}
.nh-corner.tl{top:10px;left:10px;border-right:none;border-bottom:none}
.nh-corner.tr{top:10px;right:10px;border-left:none;border-bottom:none}
.nh-corner.bl{bottom:10px;left:10px;border-right:none;border-top:none}
.nh-corner.br{bottom:10px;right:10px;border-left:none;border-top:none}
.nh-banner-content{position:relative;z-index:10;text-align:right;isolation:isolate}
.nh-banner-tag-top{color:var(--nh-pink);font-size:10px;letter-spacing:4px;font-weight:700;text-shadow:var(--nh-glow-pink)}
.nh-banner-title{
  color:#fff;font-size:54px;font-weight:900;letter-spacing:-2px;line-height:1;margin:6px 0 4px;
  text-shadow:0 0 10px rgba(255,255,255,.5),0 0 30px rgba(230,57,70,.6),0 0 60px rgba(230,57,70,.3);
  font-family:var(--nh-font-mono);
}
.nh-banner-sub{color:var(--nh-pink);font-size:15px;font-weight:300;letter-spacing:.3px}
.nh-banner-tag-bottom{color:var(--nh-pink);font-size:9px;letter-spacing:3px;font-weight:700;margin-top:12px;opacity:.8;font-family:var(--nh-font-mono)}
.nh-banner.mini{height:56px;padding:0 30px}
.nh-banner.mini .nh-banner-title{font-size:22px;letter-spacing:-1px;margin:0}
.nh-banner.mini .nh-banner-sub,.nh-banner.mini .nh-banner-tag-top{display:none}
.nh-banner.mini .nh-banner-tag-bottom{margin-top:3px;font-size:8px}
.nh-banner.mini .nh-corner{width:16px;height:16px;border-width:1px}

/* === BUTTONS === */
.btn{
  padding:10px 18px;border-radius:4px;
  border:1px solid var(--nh-border-2);
  background:var(--nh-panel-2);color:var(--nh-text);
  font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;transition:all .18s;text-decoration:none;
  font-family:var(--nh-font-mono);
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);
}
.btn:hover{background:var(--nh-panel-3);border-color:var(--nh-border-2);color:var(--nh-text)}
.btn:active{transform:translateY(1px);transition-duration:.06s}
.btn:focus-visible{outline:2px solid rgba(230,57,70,.65);outline-offset:2px;box-shadow:0 0 0 4px rgba(230,57,70,.18),var(--nh-glow-sm)}
.btn:disabled,.btn[aria-disabled="true"]{opacity:.5;cursor:not-allowed;pointer-events:none;filter:saturate(.6)}
.btn.is-loading{position:relative;color:transparent !important;pointer-events:none}
.btn.is-loading::after{content:"";position:absolute;top:50%;left:50%;width:14px;height:14px;margin:-7px 0 0 -7px;border-radius:50%;border:2px solid rgba(255,255,255,.28);border-top-color:#fff;animation:nh-btn-spin .7s linear infinite}
@keyframes nh-btn-spin{to{transform:rotate(360deg)}}
.btn-primary{
  background:rgba(230,57,70,.15);border-color:var(--nh-red);color:var(--nh-pink);
  box-shadow:var(--nh-glow-sm),inset 0 0 20px rgba(230,57,70,.05);
}
.btn-primary:hover{
  background:rgba(230,57,70,.25);border-color:var(--nh-pink);color:#fff;
  box-shadow:var(--nh-glow-red),inset 0 0 30px rgba(230,57,70,.1);
}
.btn-ghost{background:transparent;border-color:transparent}
.btn-ghost:hover{background:var(--nh-panel-2);border-color:var(--nh-border)}
.btn-lg{padding:14px 24px;font-size:13px}
.btn-sm{padding:7px 14px;font-size:10px;letter-spacing:1.2px}
.btn-danger{background:linear-gradient(135deg,rgba(230,57,70,.28),rgba(230,57,70,.12));border-color:var(--nh-red);color:var(--nh-text-bright);box-shadow:0 0 0 1px rgba(230,57,70,.25),inset 0 0 16px rgba(230,57,70,.12)}
.btn-danger:hover{background:linear-gradient(135deg,rgba(230,57,70,.45),rgba(230,57,70,.22));border-color:var(--nh-pink);color:var(--nh-text-bright);box-shadow:var(--nh-glow-red),inset 0 0 24px rgba(230,57,70,.18)}
.btn-secondary{background:rgba(230,57,70,.08);border-color:rgba(230,57,70,.4);color:var(--nh-pink)}
.btn-secondary:hover{background:rgba(230,57,70,.15);border-color:var(--nh-red);color:var(--nh-text-bright);box-shadow:var(--nh-glow-sm)}
.btn-success{background:rgba(39,174,96,.12);border-color:rgba(39,174,96,.45);color:var(--nh-success-light,#5fd084)}
.btn-success:hover{background:rgba(39,174,96,.22);border-color:var(--nh-success);color:var(--nh-text-bright);box-shadow:0 0 16px rgba(39,174,96,.3)}

/* ── Legacy button aliases — let per-page bespoke button classes inherit
   the canonical .btn styling automatically. Pages can keep using .btn-save
   / .btn-accept / etc. without per-page CSS, AND adding both classes
   (legacy + canonical) is non-breaking. */
.btn-save{
  padding:10px 18px;border-radius:4px;
  border:1px solid var(--nh-red);
  background:rgba(230,57,70,.15);color:var(--nh-pink);
  font-size:12px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;transition:all .18s;
  font-family:var(--nh-font-mono);
  clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,0 100%);
  box-shadow:var(--nh-glow-sm),inset 0 0 20px rgba(230,57,70,.05);
  cursor:pointer;
}
.btn-save:hover{background:rgba(230,57,70,.25);border-color:var(--nh-pink);color:#fff;box-shadow:var(--nh-glow-red),inset 0 0 30px rgba(230,57,70,.1)}
.btn-save:active{transform:translateY(1px);transition-duration:.06s}
.btn-save:focus-visible{outline:2px solid rgba(230,57,70,.65);outline-offset:2px;box-shadow:0 0 0 4px rgba(230,57,70,.18),var(--nh-glow-sm)}
.btn-save:disabled,.btn-save[aria-disabled="true"]{opacity:.5;cursor:not-allowed;pointer-events:none;filter:saturate(.6)}

/* === COMMON LAYOUT === */
.container{max-width:1100px;margin:0 auto;padding:48px 32px}
.section{padding:48px 0}
.section h2{font-size:24px;font-weight:900;letter-spacing:-.4px;margin-bottom:8px}
.section .lede{color:var(--nh-muted);font-size:14px;max-width:640px;line-height:1.6;margin-bottom:28px}

/* === FOOTER === */
footer.site-foot{margin-top:auto}

/* === MINIMAL PAGE FOOTER (.nh-foot) ===
   Always-loaded here (rather than only in nh-ui.css) so the footer
   is positioned correctly even if the polish CSS is stale-cached.
   position:sticky + bottom:0 keeps it pinned to the bottom of the
   scrolling .nh-content container regardless of how far the user has
   scrolled. */
.nh-foot{position:sticky;bottom:0;margin-top:auto;flex-shrink:0;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;padding:14px 30px;background:var(--nh-panel);border-top:1px solid var(--nh-border);font-family:var(--nh-font-mono);font-size:10px;letter-spacing:1.5px;color:var(--nh-dim);text-transform:uppercase;width:100%;box-sizing:border-box;z-index:40;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.nh-foot__brand{display:inline-flex;align-items:center;gap:8px;font-weight:800;color:var(--nh-muted)}
.nh-foot__brand::before{content:"";width:6px;height:6px;background:var(--nh-red);box-shadow:0 0 6px rgba(230,57,70,.6);border-radius:50%}
.nh-foot__tags{opacity:.7;letter-spacing:2.4px}
.nh-foot__meta{opacity:.55}
@media(max-width:640px){.nh-foot{padding:12px 16px;font-size:9px}.nh-foot__tags{display:none}}

/* === SIDEBAR APP LAYOUT === */
body.nh-app{flex-direction:row;overflow:hidden;height:100vh}
.nh-sidebar{
  width:230px;min-width:230px;
  background:var(--nh-panel);
  border-right:1px solid var(--nh-border);
  box-shadow:2px 0 20px rgba(0,0,0,.5),2px 0 60px rgba(100,0,150,.04);
  display:flex;flex-direction:column;height:100vh;overflow-y:auto;
  z-index:100;flex-shrink:0;
  scrollbar-width:thin;scrollbar-color:var(--nh-border) transparent;
}
.nh-content{flex:1;min-width:0;height:100vh;overflow-y:auto;display:flex;flex-direction:column}

/* Sidebar brand */
.nhsb-brand{
  display:flex;align-items:center;gap:10px;padding:14px 14px 12px;
  border-bottom:1px solid var(--nh-border);
  background:linear-gradient(135deg,rgba(164,22,26,.12) 0%,transparent 100%);
}
.nhsb-brand-icon{font-size:18px;color:var(--nh-red);line-height:1;filter:drop-shadow(0 0 6px rgba(230,57,70,.7))}
.nhsb-logo{font-size:13px;font-weight:900;color:#fff;letter-spacing:1px;line-height:1;font-family:var(--nh-font-mono);text-shadow:0 0 12px rgba(255,255,255,.3)}
.nhsb-tagline{font-size:8px;color:var(--nh-pink);letter-spacing:2.5px;font-weight:700;text-transform:uppercase;margin-top:3px;opacity:.8}

/* User pill */
.nhsb-user{display:flex;align-items:center;gap:9px;padding:10px 14px;border-bottom:1px solid var(--nh-border)}
.nhsb-av{
  width:32px;height:32px;border-radius:4px;
  background:linear-gradient(135deg,var(--nh-red),var(--nh-red-dark));
  display:flex;align-items:center;justify-content:center;
  font-weight:900;font-size:13px;color:#fff;overflow:hidden;flex-shrink:0;
  border:1px solid rgba(230,57,70,.5);
  box-shadow:0 0 8px rgba(230,57,70,.3);
  font-family:var(--nh-font-mono);
}
.nhsb-av img{width:100%;height:100%;object-fit:cover;border-radius:3px}
.nhsb-uinfo{min-width:0;flex:1}
.nhsb-uname{font-size:12px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-family:var(--nh-font-mono)}
.nhsb-urank{font-size:8px;color:var(--nh-pink);text-transform:uppercase;letter-spacing:2px;font-weight:800;margin-top:2px;opacity:.9}

/* Nav items — button style */
.nhsb-section{padding:6px 8px 4px}
.nhsb-divider{height:1px;background:linear-gradient(90deg,transparent,var(--nh-border) 30%,var(--nh-border) 70%,transparent);margin:6px 0}

.nhsb-item{
  display:flex;align-items:center;gap:9px;padding:7px 10px;
  border-radius:7px;font-size:12px;font-weight:600;color:var(--nh-muted);
  text-decoration:none;transition:all .16s ease;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  border:1px solid transparent;font-family:var(--nh-font-mono);letter-spacing:.3px;
  background:transparent;position:relative;
}
.nhsb-item:hover{
  background:rgba(255,255,255,.04);
  border-color:rgba(255,255,255,.06);
  color:var(--nh-text);
  box-shadow:0 2px 8px rgba(0,0,0,.25);
}
.nhsb-item:hover .nhsb-ic{
  background:rgba(255,255,255,.07);
  border-color:rgba(255,255,255,.1);
  color:var(--nh-text);
}
.nhsb-item.active{
  background:rgba(230,57,70,.13);
  border-color:rgba(230,57,70,.32);
  color:#fff;
  box-shadow:0 0 14px rgba(230,57,70,.18), inset 0 0 14px rgba(230,57,70,.05), 0 2px 6px rgba(0,0,0,.3);
}
.nhsb-item.active::before{
  content:"";position:absolute;left:-1px;top:6px;bottom:6px;width:3px;
  background:var(--nh-red);border-radius:0 3px 3px 0;
  box-shadow:0 0 10px rgba(230,57,70,.7);
}
.nhsb-item.active .nhsb-ic{
  background:rgba(230,57,70,.28);
  border-color:rgba(230,57,70,.5);
  color:var(--nh-pink);
  box-shadow:0 0 10px rgba(230,57,70,.45), inset 0 0 6px rgba(230,57,70,.15);
}
.nhsb-item.soon{opacity:.28;cursor:default;pointer-events:none}
.nhsb-item.soon::after{content:'SOON';font-size:7px;letter-spacing:1.5px;font-weight:800;color:var(--nh-dim);margin-left:auto}

.nhsb-ic{
  font-size:13px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:6px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  transition:all .16s ease;
}
.nhsb-item-indent{padding-left:20px}

/* Tool zones */
.nhsb-tool{overflow:hidden}
.nhsb-tool-hdr{
  display:flex;align-items:center;gap:8px;padding:6px 10px;margin:2px 0;
  cursor:pointer;user-select:none;
  border-radius:7px;border:1px solid transparent;
  transition:all .16s ease;
}
.nhsb-tool-hdr:hover{
  background:rgba(255,255,255,.03);
  border-color:rgba(255,255,255,.06);
}
.nhsb-chev{font-size:8px;color:var(--nh-dim);transition:transform .2s;flex-shrink:0;line-height:1}
.nhsb-tool.open .nhsb-chev{transform:rotate(90deg)}
.nhsb-tool-label{
  font-size:9px;letter-spacing:3px;text-transform:uppercase;font-weight:900;
  color:var(--nh-pink);flex:1;font-family:var(--nh-font-mono);
  text-shadow:0 0 8px rgba(255,107,122,.35);
}
.nhsb-tool-label.dim{color:var(--nh-dim);text-shadow:none}
.nhsb-tool-soon{font-size:7px;letter-spacing:1.5px;font-weight:800;color:var(--nh-dim);font-family:var(--nh-font-mono)}
.nhsb-tool-body{display:none;padding:2px 0 6px}
.nhsb-tool.open .nhsb-tool-body{display:block}

/* Sidebar footer */
.nhsb-footer{margin-top:auto;padding:10px 8px;border-top:1px solid var(--nh-border)}
.nhsb-signout{
  display:flex;align-items:center;gap:9px;padding:7px 10px;
  border-radius:7px;border:1px solid transparent;
  font-size:11px;font-weight:700;color:var(--nh-muted);text-decoration:none;
  letter-spacing:.5px;transition:all .16s ease;font-family:var(--nh-font-mono);
}
.nhsb-signout:hover{
  background:rgba(230,57,70,.1);
  border-color:rgba(230,57,70,.28);
  color:var(--nh-pink);
  box-shadow:0 0 10px rgba(230,57,70,.14);
}

/* === CYBERPUNK ANIMATIONS === */
@keyframes nh-flicker{
  0%,96%,100%{opacity:1}
  97%{opacity:.85}
  98%{opacity:1}
  99%{opacity:.9}
}
@keyframes nh-glitch{
  0%,90%,100%{transform:translate(0)}
  91%{transform:translate(-2px,0);text-shadow:2px 0 var(--nh-pink),0 0 20px rgba(230,57,70,.8)}
  92%{transform:translate(2px,0);text-shadow:-2px 0 rgba(46,117,182,.8),0 0 20px rgba(230,57,70,.8)}
  93%{transform:translate(0)}
  94%{transform:translate(1px,-1px)}
  95%{transform:translate(0)}
}
@keyframes nh-neon-pulse{
  0%,100%{box-shadow:var(--nh-glow-sm)}
  50%{box-shadow:var(--nh-glow-red)}
}
@keyframes nh-scanline{
  0%{background-position:0 0}
  100%{background-position:0 100px}
}
@keyframes nh-blink{
  0%,100%{opacity:1}50%{opacity:0}
}
@keyframes nh-fade-up{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:translateY(0)}
}

.nh-glitch{animation:nh-glitch 8s infinite,nh-flicker 12s infinite}
.nh-blink{animation:nh-blink 1.2s step-end infinite}
.nh-fade-up{animation:nh-fade-up .35s ease forwards}

/* Cursor blink for terminal elements */
.nh-cursor::after{content:'█';animation:nh-blink 1s step-end infinite;color:var(--nh-red);font-size:.85em;margin-left:2px}

/* Neon text utilities */
.text-glow-red{text-shadow:var(--nh-glow-red);color:var(--nh-pink)}
.text-glow-sm{text-shadow:0 0 8px rgba(230,57,70,.6)}

/* Panel neon accent */
.panel-neon::before{box-shadow:0 0 8px rgba(230,57,70,.5)}

/* ── MOBILE NAV BAR (injected by sidebar JS) ── */
.nh-mob-nav{
  display:none;align-items:center;gap:10px;padding:10px 14px;
  background:var(--nh-panel);border-bottom:1px solid var(--nh-border);
  position:sticky;top:0;z-index:150;flex-shrink:0;
}
.nh-mob-toggle{
  width:36px;height:36px;border-radius:4px;background:var(--nh-panel-2);
  border:1px solid var(--nh-border);color:var(--nh-pink);font-size:18px;
  cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.nh-mob-brand{font-size:13px;font-weight:900;color:#fff;letter-spacing:1px;font-family:var(--nh-font-mono);flex:1}
.nh-mob-status{font-size:8px;letter-spacing:1.5px;font-family:var(--nh-font-mono);color:var(--nh-success);font-weight:800;text-transform:uppercase;display:flex;align-items:center;gap:4px;flex-shrink:0}
.nh-mob-status-dot{width:5px;height:5px;border-radius:50%;background:var(--nh-success);box-shadow:0 0 5px rgba(39,174,96,.8)}
.nh-mob-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:190;cursor:pointer}
.nh-mob-overlay.show{display:block}

@media(max-width:768px){
  /* Sidebar: slide-in overlay drawer */
  body.nh-app{flex-direction:column;height:auto;overflow-x:hidden;overflow-y:auto}
  .nh-content{height:auto;overflow-y:visible;overflow-x:hidden;min-height:100vh;max-width:100vw}
  .nh-sidebar{
    position:fixed;top:0;left:-240px;height:100vh;z-index:200;
    display:flex;transition:left .25s cubic-bezier(.4,0,.2,1);
    box-shadow:none;width:230px;min-width:230px;overflow-y:auto;
  }
  .nh-sidebar.nh-open{left:0;box-shadow:4px 0 40px rgba(0,0,0,.6)}
  .nh-mob-nav{display:flex}

  /* Banner — auto height, centered on mobile */
  .nh-banner{height:auto;min-height:72px;padding:14px 20px;justify-content:center;text-align:center}
  .nh-banner-content{text-align:center}
  .nh-banner-title{font-size:28px;letter-spacing:-1px}
  .nh-banner-sub{font-size:10px}
  .nh-banner-tag-top{font-size:8px;letter-spacing:2px}
  .nh-banner-tag-bottom{font-size:7px;letter-spacing:1.5px;margin-top:6px}
  .nh-banner.mini{height:48px;padding:0 14px;justify-content:flex-end}
  .nh-banner.mini .nh-banner-content{text-align:right}
  .nh-banner.mini .nh-banner-title{font-size:18px}

  /* Common layout */
  .container{padding:16px}
}

@media(max-width:480px){
  .nh-banner{height:56px}
  .nh-banner-title{font-size:22px}
}

/* ── LEGACY STAFF TOPBAR + TABS (shared mobile fix) ── */
@media(max-width:768px){
  /* Topbar */
  .topbar{padding:10px 14px;gap:8px;flex-wrap:wrap}
  .tb-l{gap:8px}
  .tb-title{display:none}
  /* Tabs: horizontal scroll strip */
  .tabs{
    display:flex;overflow-x:auto;overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;padding:0 4px;
    border-bottom:1px solid var(--nh-border)
  }
  .tabs::-webkit-scrollbar{display:none}
  .tab{
    padding:11px 12px;font-size:10px;letter-spacing:.6px;
    white-space:nowrap;flex-shrink:0
  }
  /* Wrap */
  .wrap{padding:14px !important}
  /* Btn groups */
  .btn{padding:8px 12px;font-size:10px;letter-spacing:.8px}
}
