/*
Theme Name: Neamo Ultima
Theme URI: https://neamogroup.com
Author: Neamo Group
Author URI: https://neamogroup.com
Description: A modern, multi-discipline government contractor theme for Neamo Group. Blends the clean visual design of Jacobs, the infrastructure positioning of AECOM, the government-contractor credibility of KBR, the technology-integration presentation of AVI-SPL, and the security-systems organization of Convergint. All homepage content is editable via the Customizer; supporting content lives in editable Pages.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 7.0
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: neamo_ultima
*/

/* =========================================================================
   1. Design tokens
   ========================================================================= */
:root {
  --nm-navy-900: #07172e;
  --nm-navy-800: #0b2545;
  --nm-navy-700: #123a63;
  --nm-blue-600: #1d6fb8;
  --nm-blue-500: #2a86d8;
  --nm-cyan-400: #19b4c4;
  --nm-amber-500: #f5a623;
  --nm-slate-900: #0f172a;
  --nm-slate-700: #334155;
  --nm-slate-500: #64748b;
  --nm-slate-300: #cbd5e1;
  --nm-slate-100: #eef2f7;
  --nm-slate-50:  #f6f8fb;
  --nm-white: #ffffff;

  --nm-font-head: "Archivo", "Helvetica Neue", Arial, sans-serif;
  --nm-font-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;

  --nm-maxw: 1240px;
  --nm-gap: clamp(1.25rem, 3vw, 2.5rem);
  --nm-radius: 14px;
  --nm-radius-sm: 8px;
  --nm-shadow-sm: 0 1px 2px rgba(7,23,46,.06), 0 2px 8px rgba(7,23,46,.06);
  --nm-shadow-md: 0 10px 30px rgba(7,23,46,.10);
  --nm-shadow-lg: 0 24px 60px rgba(7,23,46,.18);
  --nm-ease: cubic-bezier(.16,.84,.44,1);
}

/* Accessibility */
.screen-reader-text { position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
.screen-reader-text:focus { position:fixed !important; top:12px; left:12px; width:auto; height:auto; clip:auto; z-index:1000; padding:.7rem 1.1rem; background:#fff; color:var(--nm-navy-900); border-radius:8px; box-shadow:0 6px 24px rgba(0,0,0,.2); }
.nm-pagination, .pagination { margin-top:2.5rem; display:flex; gap:.5rem; flex-wrap:wrap; }
.nm-pagination .page-numbers, .pagination .page-numbers { padding:.5rem .9rem; border:1px solid var(--nm-slate-300); border-radius:8px; font-family:var(--nm-font-head); font-weight:600; }
.nm-pagination .current, .pagination .current { background:var(--nm-navy-800); color:#fff; border-color:var(--nm-navy-800); }

/* =========================================================================
   2. Reset / base
   ========================================================================= */
*,*::before,*::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--nm-font-body);
  color: var(--nm-slate-700);
  background: var(--nm-white);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--nm-blue-600); text-decoration: none; transition: color .2s var(--nm-ease); }
a:hover { color: var(--nm-navy-800); }
h1,h2,h3,h4,h5 {
  font-family: var(--nm-font-head);
  color: var(--nm-navy-900);
  line-height: 1.12;
  font-weight: 700;
  letter-spacing: -.01em;
  margin: 0 0 .6em;
}
p { margin: 0 0 1.1em; }
ul,ol { margin: 0 0 1.1em; padding-left: 1.2em; }

/* =========================================================================
   3. Layout helpers
   ========================================================================= */
.nm-container { width: 100%; max-width: var(--nm-maxw); margin-inline: auto; padding-inline: clamp(1.1rem, 4vw, 2.5rem); }
.nm-section { padding-block: clamp(3.5rem, 7vw, 6.5rem); }
.nm-section--tight { padding-block: clamp(2.5rem, 5vw, 4rem); }
.nm-section--navy { background: var(--nm-navy-900); color: var(--nm-slate-100); }
.nm-section--navy h2,.nm-section--navy h3 { color: #fff; }
.nm-section--slate { background: var(--nm-slate-50); }
.nm-eyebrow {
  display: inline-flex; align-items: center; gap: .5rem;
  font-family: var(--nm-font-head);
  font-weight: 600; font-size: .78rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--nm-blue-600); margin: 0 0 1rem;
}
.nm-section--navy .nm-eyebrow { color: var(--nm-cyan-400); }
.nm-eyebrow::before { content:""; width: 26px; height: 2px; background: currentColor; display:inline-block; }
.nm-section-head { max-width: 760px; margin-bottom: clamp(2rem, 4vw, 3.25rem); }
.nm-section-head h2 { font-size: clamp(1.8rem, 3.6vw, 2.8rem); }
.nm-section-head p { font-size: 1.12rem; color: var(--nm-slate-500); margin-bottom: 0; }
.nm-section--navy .nm-section-head p { color: var(--nm-slate-300); }
.nm-center { text-align: center; margin-inline: auto; }

/* =========================================================================
   4. Buttons
   ========================================================================= */
.nm-btn {
  --bg: var(--nm-blue-600); --fg: #fff;
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: var(--nm-font-head); font-weight: 600; font-size: .98rem;
  padding: .92rem 1.6rem; border-radius: var(--nm-radius-sm);
  background: var(--bg); color: var(--fg); border: 2px solid var(--bg);
  cursor: pointer; transition: transform .2s var(--nm-ease), background .2s var(--nm-ease), box-shadow .2s var(--nm-ease);
  line-height: 1;
}
.nm-btn:hover { background: var(--nm-navy-800); border-color: var(--nm-navy-800); color:#fff; transform: translateY(-2px); box-shadow: var(--nm-shadow-md); }
.nm-btn--ghost { --bg: transparent; --fg: #fff; border-color: rgba(255,255,255,.55); }
.nm-btn--ghost:hover { background: #fff; color: var(--nm-navy-900); border-color:#fff; }
.nm-btn--amber { --bg: var(--nm-amber-500); --fg: var(--nm-navy-900); }
.nm-btn--amber:hover { background:#ffb840; border-color:#ffb840; color: var(--nm-navy-900); }
.nm-btn--outline-dark { --bg: transparent; --fg: var(--nm-navy-800); border-color: var(--nm-slate-300); }
.nm-btn--outline-dark:hover { background: var(--nm-navy-800); color:#fff; border-color: var(--nm-navy-800); }
.nm-btn-row { display:flex; flex-wrap: wrap; gap: .9rem; }

/* =========================================================================
   5. Header / nav
   ========================================================================= */
.nm-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(255,255,255,.92); backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--nm-slate-100);
  transition: box-shadow .3s var(--nm-ease);
}
.nm-header.is-stuck { box-shadow: var(--nm-shadow-sm); }
.nm-header__inner { display:flex; align-items:center; justify-content: space-between; gap: 2rem; min-height: 76px; }
.nm-brand { display:flex; align-items:center; gap:.7rem; font-family: var(--nm-font-head); font-weight: 800; font-size: 1.35rem; color: var(--nm-navy-900); letter-spacing:-.02em; }
.nm-brand:hover { color: var(--nm-navy-900); }
.nm-brand img { display:block; height:auto; width:auto; max-height: 46px; max-width: min(240px, 50vw); object-fit: contain; }
.nm-brand__mark { display:inline-grid; place-items:center; width: 40px; height: 40px; border-radius: 10px; background: linear-gradient(135deg, var(--nm-blue-600), var(--nm-cyan-400)); color:#fff; font-weight:800; }
.nm-brand__tag { display:block; font-family: var(--nm-font-body); font-weight:500; font-size:.62rem; letter-spacing:.14em; text-transform:uppercase; color: var(--nm-slate-500); margin-top:2px; }

.nm-nav { display:flex; align-items:center; gap: 1.9rem; }
.nm-menu { display:flex; align-items:center; gap: 1.6rem; list-style:none; margin:0; padding:0; }
.nm-menu a { font-family: var(--nm-font-head); font-weight: 600; font-size: .96rem; color: var(--nm-slate-700); position: relative; padding: .4rem 0; }
.nm-menu a:hover, .nm-menu .current-menu-item > a { color: var(--nm-navy-900); }
.nm-menu a::after { content:""; position:absolute; left:0; bottom:-2px; height:2px; width:0; background: var(--nm-blue-600); transition: width .25s var(--nm-ease); }
.nm-menu a:hover::after, .nm-menu .current-menu-item > a::after { width:100%; }
/* dropdown */
.nm-menu .sub-menu { position:absolute; top:100%; left:0; min-width: 250px; background:#fff; border:1px solid var(--nm-slate-100); border-radius: var(--nm-radius-sm); box-shadow: var(--nm-shadow-md); padding:.5rem; list-style:none; margin:0; opacity:0; visibility:hidden; transform: translateY(8px); transition: all .2s var(--nm-ease); }
.nm-menu .menu-item-has-children { position: relative; }
.nm-menu .menu-item-has-children:hover > .sub-menu { opacity:1; visibility:visible; transform: translateY(4px); }
.nm-menu .sub-menu a { display:block; padding:.6rem .8rem; border-radius:6px; font-weight:500; }
.nm-menu .sub-menu a::after { display:none; }
.nm-menu .sub-menu a:hover { background: var(--nm-slate-50); }

.nm-burger { display:none; flex-direction:column; gap:5px; background:none; border:0; cursor:pointer; padding:8px; }
.nm-burger span { width:26px; height:2px; background: var(--nm-navy-900); transition: all .25s var(--nm-ease); }
.nm-burger.is-open span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nm-burger.is-open span:nth-child(2){ opacity:0; }
.nm-burger.is-open span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }

/* =========================================================================
   6. Hero
   ========================================================================= */
.nm-hero { position: relative; isolation:isolate; color:#fff; overflow:hidden; min-height: clamp(560px, 86vh, 820px); display:flex; align-items:center; }
.nm-hero__media { position:absolute; inset:0; z-index:-2; }
.nm-hero__media video, .nm-hero__media img { width:100%; height:100%; object-fit:cover; }
.nm-hero__fallback { position:absolute; inset:0; z-index:-2; background:
  radial-gradient(1200px 600px at 80% -10%, rgba(25,180,196,.25), transparent 60%),
  radial-gradient(900px 500px at 10% 110%, rgba(29,111,184,.35), transparent 55%),
  linear-gradient(135deg, #061427 0%, #0b2545 55%, #123a63 100%); }
.nm-hero__overlay { position:absolute; inset:0; z-index:-1; background: linear-gradient(90deg, rgba(6,16,35,.86) 0%, rgba(6,16,35,.62) 45%, rgba(6,16,35,.30) 100%); }
.nm-hero__grid { position:absolute; inset:0; z-index:-1; opacity:.18; background-image: linear-gradient(rgba(255,255,255,.18) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.18) 1px, transparent 1px); background-size: 64px 64px; mask-image: radial-gradient(120% 120% at 70% 20%, #000 30%, transparent 75%); }
.nm-hero__inner { padding-block: clamp(4rem, 9vw, 7rem); max-width: 880px; }
.nm-hero .nm-eyebrow { color: var(--nm-cyan-400); }
.nm-hero h1 { color:#fff; font-size: clamp(2.4rem, 5.6vw, 4.4rem); line-height: 1.04; margin-bottom: 1.1rem; }
.nm-hero__lede { font-size: clamp(1.1rem, 1.8vw, 1.35rem); color: var(--nm-slate-300); max-width: 640px; margin-bottom: 2rem; }
.nm-hero__stats { display:flex; flex-wrap:wrap; gap: clamp(1.5rem,4vw,3rem); margin-top: 3rem; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,.15); }
.nm-stat__num { font-family: var(--nm-font-head); font-weight:800; font-size: 2.1rem; color:#fff; line-height:1; }
.nm-stat__label { font-size:.86rem; color: var(--nm-slate-300); letter-spacing:.02em; }

/* =========================================================================
   7. Capability cards
   ========================================================================= */
.nm-cards { display:grid; grid-template-columns: repeat(4, 1fr); gap: 1.4rem; }
.nm-card {
  position:relative; display:flex; flex-direction:column;
  background:#fff; border:1px solid var(--nm-slate-100); border-radius: var(--nm-radius);
  padding: 2rem 1.7rem 1.8rem; overflow:hidden;
  transition: transform .3s var(--nm-ease), box-shadow .3s var(--nm-ease), border-color .3s var(--nm-ease);
  min-height: 280px;
}
.nm-card::before { content:""; position:absolute; left:0; top:0; height:4px; width:100%; background: linear-gradient(90deg, var(--nm-blue-600), var(--nm-cyan-400)); transform: scaleX(0); transform-origin:left; transition: transform .35s var(--nm-ease); }
.nm-card:hover { transform: translateY(-6px); box-shadow: var(--nm-shadow-lg); border-color: transparent; }
.nm-card:hover::before { transform: scaleX(1); }
.nm-card__icon { width:54px; height:54px; border-radius:12px; display:grid; place-items:center; background: var(--nm-slate-50); color: var(--nm-blue-600); margin-bottom: 1.2rem; }
.nm-card__icon svg { width:28px; height:28px; }
.nm-card h3 { font-size: 1.22rem; margin-bottom:.5rem; }
.nm-card p { font-size:.96rem; color: var(--nm-slate-500); margin-bottom: 1.2rem; }
.nm-card__link { margin-top:auto; font-family: var(--nm-font-head); font-weight:600; font-size:.92rem; color: var(--nm-blue-600); display:inline-flex; align-items:center; gap:.4rem; }
.nm-card__link svg { transition: transform .25s var(--nm-ease); }
.nm-card:hover .nm-card__link svg { transform: translateX(4px); }

/* =========================================================================
   8. Markets grid (interactive)
   ========================================================================= */
.nm-markets { display:grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.10); border-radius: var(--nm-radius); overflow:hidden; }
.nm-market {
  position:relative; background: var(--nm-navy-800); color:#fff; padding: 1.8rem 1.5rem; min-height: 178px;
  display:flex; flex-direction:column; justify-content:flex-end; cursor:default; overflow:hidden;
  transition: background .3s var(--nm-ease);
}
.nm-market::after { content:""; position:absolute; inset:0; background: linear-gradient(160deg, rgba(29,111,184,.0), rgba(25,180,196,.0)); transition: all .3s var(--nm-ease); }
.nm-market:hover { background: var(--nm-navy-700); }
.nm-market:hover::after { background: linear-gradient(160deg, rgba(29,111,184,.35), rgba(25,180,196,.18)); }
.nm-market__icon { width:34px; height:34px; color: var(--nm-cyan-400); margin-bottom: auto; position:relative; z-index:1; transition: transform .3s var(--nm-ease); }
.nm-market:hover .nm-market__icon { transform: translateY(-4px); }
.nm-market__name { font-family: var(--nm-font-head); font-weight:700; font-size:1.12rem; position:relative; z-index:1; }
.nm-market__desc { font-size:.84rem; color: var(--nm-slate-300); position:relative; z-index:1; max-height:0; opacity:0; overflow:hidden; transition: all .35s var(--nm-ease); margin-top:.3rem; }
.nm-market:hover .nm-market__desc { max-height: 90px; opacity:1; }

/* =========================================================================
   9. Strategic Partner Network
   ========================================================================= */
.nm-partner { display:grid; grid-template-columns: 1.05fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items:center; }
.nm-partner__disciplines { display:grid; grid-template-columns: 1fr 1fr; gap:.8rem; }
.nm-discipline { display:flex; align-items:center; gap:.75rem; background:#fff; border:1px solid var(--nm-slate-100); border-radius: var(--nm-radius-sm); padding: .9rem 1.1rem; font-family: var(--nm-font-head); font-weight:600; font-size:.95rem; color: var(--nm-navy-800); box-shadow: var(--nm-shadow-sm); transition: transform .25s var(--nm-ease); }
.nm-discipline:hover { transform: translateY(-3px); }
.nm-discipline__dot { width:10px; height:10px; border-radius:50%; background: linear-gradient(135deg, var(--nm-blue-600), var(--nm-cyan-400)); flex:none; }

/* =========================================================================
   10. Why Neamo
   ========================================================================= */
.nm-why { display:grid; grid-template-columns: repeat(4,1fr); gap: 1.5rem; }
.nm-why__item { text-align:left; padding: 1.6rem; border-radius: var(--nm-radius); background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); transition: background .3s var(--nm-ease); }
.nm-why__item:hover { background: rgba(255,255,255,.07); }
.nm-why__icon { width:56px; height:56px; border-radius:12px; display:grid; place-items:center; background: linear-gradient(135deg, rgba(29,111,184,.25), rgba(25,180,196,.18)); color: var(--nm-cyan-400); margin-bottom:1.1rem; }
.nm-why__icon svg { width:28px; height:28px; }
.nm-why__item h3 { font-size:1.1rem; color:#fff; margin-bottom:.4rem; }
.nm-why__item p { font-size:.92rem; color: var(--nm-slate-300); margin:0; }

/* =========================================================================
   11. Capability Statement CTA
   ========================================================================= */
.nm-capcta { position:relative; overflow:hidden; border-radius: clamp(16px, 3vw, 26px); background: linear-gradient(120deg, var(--nm-navy-900), var(--nm-navy-700)); color:#fff; padding: clamp(2.5rem, 6vw, 4.5rem); display:grid; grid-template-columns: 1.4fr 1fr; gap: 2rem; align-items:center; }
.nm-capcta::before { content:""; position:absolute; right:-120px; top:-120px; width:420px; height:420px; border-radius:50%; background: radial-gradient(circle, rgba(25,180,196,.35), transparent 60%); }
.nm-capcta h2 { color:#fff; font-size: clamp(1.7rem, 3.4vw, 2.5rem); margin-bottom:.6rem; }
.nm-capcta p { color: var(--nm-slate-300); margin-bottom:0; max-width: 560px; }
.nm-capcta__actions { display:flex; flex-direction:column; gap:.9rem; position:relative; z-index:1; }
.nm-capcta__meta { display:flex; flex-wrap:wrap; gap:.5rem 1.4rem; margin-top:1.5rem; font-size:.82rem; color: var(--nm-slate-300); }
.nm-capcta__meta strong { color:#fff; font-family: var(--nm-font-head); }

/* =========================================================================
   12. Footer
   ========================================================================= */
.nm-footer { background: var(--nm-navy-900); color: var(--nm-slate-300); padding-block: clamp(3rem,6vw,4.5rem) 2rem; }
.nm-footer__grid { display:grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: 2.5rem; padding-bottom: 2.5rem; border-bottom:1px solid rgba(255,255,255,.10); }
.nm-footer h4 { color:#fff; font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:1.1rem; }
.nm-footer ul { list-style:none; padding:0; margin:0; }
.nm-footer li { margin-bottom:.6rem; }
.nm-footer a { color: var(--nm-slate-300); font-size:.95rem; }
.nm-footer a:hover { color:#fff; }
.nm-footer__brand { font-family: var(--nm-font-head); font-weight:800; font-size:1.4rem; color:#fff; margin-bottom:.8rem; display:inline-flex; align-items:center; gap:.6rem; }
.nm-footer__about { font-size:.95rem; max-width:340px; }
.nm-footer__bottom { display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; padding-top:1.6rem; font-size:.85rem; color: var(--nm-slate-500); }
.nm-footer__caps { display:flex; flex-wrap:wrap; gap:.6rem; margin-top:1.2rem; }
.nm-chip { font-family: var(--nm-font-head); font-size:.72rem; font-weight:600; letter-spacing:.04em; padding:.35rem .7rem; border:1px solid rgba(255,255,255,.18); border-radius:999px; color: var(--nm-slate-300); }

/* =========================================================================
   13. Generic page / content
   ========================================================================= */
.nm-page-hero { background: var(--nm-navy-900); color:#fff; padding-block: clamp(3.5rem,7vw,6rem); position:relative; overflow:hidden; }
.nm-page-hero::after { content:""; position:absolute; inset:0; z-index:0; opacity:.5; background:
  radial-gradient(700px 360px at 85% -20%, rgba(25,180,196,.22), transparent 60%),
  radial-gradient(700px 360px at 0% 120%, rgba(29,111,184,.30), transparent 55%); }
.nm-page-hero > * { position:relative; z-index:1; }
.nm-page-hero h1 { color:#fff; font-size: clamp(2rem,4.4vw,3.2rem); margin-bottom:.6rem; }
.nm-page-hero p { color: var(--nm-slate-300); font-size:1.12rem; max-width:680px; margin:0; }
.nm-breadcrumbs { font-size:.84rem; color: var(--nm-slate-300); margin-bottom:1.2rem; }
.nm-breadcrumbs a { color: var(--nm-cyan-400); }
.nm-content { max-width: 820px; }
.nm-content.nm-content--wide { max-width: var(--nm-maxw); }
.nm-content h2 { font-size: clamp(1.5rem,3vw,2.1rem); margin-top:2.2rem; }
.nm-content h3 { font-size:1.3rem; margin-top:1.8rem; }
.nm-content img { border-radius: var(--nm-radius); margin-block:1.5rem; }
.nm-content ul { list-style:none; padding:0; }
.nm-content ul li { position:relative; padding-left:1.7rem; margin-bottom:.6rem; }
.nm-content ul li::before { content:""; position:absolute; left:0; top:.55em; width:8px; height:8px; border-radius:2px; background: linear-gradient(135deg, var(--nm-blue-600), var(--nm-cyan-400)); }
.nm-content blockquote { border-left:4px solid var(--nm-blue-600); margin:1.5rem 0; padding:.4rem 0 .4rem 1.4rem; font-size:1.2rem; color: var(--nm-navy-800); font-style:italic; }

/* feature list used in division pages */
.nm-featgrid { display:grid; grid-template-columns: repeat(auto-fit,minmax(240px,1fr)); gap:1.4rem; margin:2rem 0; }
.nm-feat { background:#fff; border:1px solid var(--nm-slate-100); border-radius:var(--nm-radius); padding:1.6rem; box-shadow:var(--nm-shadow-sm); }
.nm-feat h3 { font-size:1.08rem; margin-bottom:.4rem; }
.nm-feat p { font-size:.94rem; color:var(--nm-slate-500); margin:0; }

/* =========================================================================
   14. Reveal animation
   ========================================================================= */
.nm-reveal { opacity:0; transform: translateY(24px); transition: opacity .7s var(--nm-ease), transform .7s var(--nm-ease); }
.nm-reveal.is-in { opacity:1; transform:none; }
@media (prefers-reduced-motion: reduce) { .nm-reveal { opacity:1; transform:none; transition:none; } html { scroll-behavior:auto; } }

/* =========================================================================
   15. Responsive
   ========================================================================= */
@media (max-width: 1024px) {
  .nm-cards { grid-template-columns: repeat(2,1fr); }
  .nm-markets { grid-template-columns: repeat(2,1fr); }
  .nm-why { grid-template-columns: repeat(2,1fr); }
  .nm-footer__grid { grid-template-columns: 1fr 1fr; }
  .nm-capcta { grid-template-columns: 1fr; }
  .nm-partner { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .nm-burger { display:flex; }
  .nm-nav { position: fixed; inset: 76px 0 auto 0; background:#fff; flex-direction:column; align-items:stretch; gap:0; padding: 1rem clamp(1.1rem,4vw,2.5rem) 1.5rem; border-bottom:1px solid var(--nm-slate-100); box-shadow: var(--nm-shadow-md); transform: translateY(-12px); opacity:0; visibility:hidden; transition: all .25s var(--nm-ease); max-height: calc(100vh - 76px); overflow-y:auto; }
  .nm-nav.is-open { transform:none; opacity:1; visibility:visible; }
  .nm-menu { flex-direction:column; align-items:stretch; gap:0; width:100%; }
  .nm-menu li { border-bottom:1px solid var(--nm-slate-100); }
  .nm-menu a { display:block; padding:.95rem 0; }
  .nm-menu a::after { display:none; }
  .nm-menu .sub-menu { position:static; opacity:1; visibility:visible; transform:none; box-shadow:none; border:0; padding:0 0 .6rem 1rem; }
  .nm-nav .nm-btn { margin-top:1rem; justify-content:center; }
}
@media (max-width: 600px) {
  .nm-cards, .nm-markets, .nm-why, .nm-footer__grid, .nm-partner__disciplines { grid-template-columns: 1fr; }
  body { font-size: 16px; }
  .nm-brand img { max-height: 38px; max-width: min(180px, 60vw); }
}
