/* ============================================================
   NewMedSkills — public site styles
   Translates the design-system JSX component/section inline styles
   into reusable classes. Tokens come from design/styles.css.
   ============================================================ */

html { scroll-behavior: smooth; }
body { margin: 0; background: var(--cream-200); }
img { max-width: 100%; display: block; }
button { font-family: var(--font-sans); }

/* ---- Layout ---- */
.nms-container {
  width: 100%; max-width: var(--container-max);
  margin: 0 auto; padding: 0 var(--container-pad);
}
.nms-section { padding: var(--section-y) 0; }
.nms-section.bg-cream  { background: var(--cream-200); }
.nms-section.bg-alt    { background: var(--cream-100); }
.nms-section.bg-greige { background: var(--greige-300); }
.nms-section.bg-dark   { background: var(--brown-900); color: var(--text-on-dark); }

/* ---- Wordmark ---- */
.nms-wordmark {
  display: inline-flex; align-items: baseline;
  font-weight: 800; font-size: 24px; letter-spacing: -0.03em; line-height: 1;
}
.nms-wordmark--sm { font-size: 22px; }
.nms-wordmark--lg { font-size: 26px; }
.nms-wordmark .wm-new    { color: var(--brown-900); }
.nms-wordmark .wm-med    { color: var(--orange-500); }
.nms-wordmark .wm-skills { color: var(--brown-500); font-weight: 600; font-size: 0.55em; margin-left: 3px; letter-spacing: 0.04em; }
.nms-wordmark.on-dark .wm-new { color: #fff; }

/* ---- Eyebrow (overline) ---- */
.nms-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .75rem; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--orange-500);
}
.nms-eyebrow::before { content: ""; width: 22px; height: 2px; background: currentColor; border-radius: 2px; }
.nms-eyebrow.on-dark { color: var(--orange-300); }

/* ---- Section head ---- */
.nms-sectionhead {
  display: flex; flex-direction: column; gap: 16px;
  max-width: 720px; margin-bottom: 56px;
}
.nms-sectionhead.is-center { margin-left: auto; margin-right: auto; text-align: center; align-items: center; }
.nms-sectionhead h2 {
  font-size: clamp(2rem, 4vw, 3rem); font-weight: 800;
  letter-spacing: -0.025em; line-height: 1.08; color: var(--text-primary);
}
.nms-sectionhead .lead { font-size: 1.1875rem; line-height: 1.6; color: var(--text-secondary); }
.on-dark .nms-sectionhead h2, .nms-sectionhead.on-dark h2 { color: #fff; }
.on-dark .nms-sectionhead .lead, .nms-sectionhead.on-dark .lead { color: rgba(248,245,238,0.78); }

/* ---- Buttons ---- */
.nms-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-family: var(--font-sans); font-weight: 600; letter-spacing: -0.01em; line-height: 1;
  cursor: pointer; border: 1px solid transparent; text-decoration: none;
  transition: background .12s var(--ease-out), box-shadow .2s var(--ease-out), transform .12s var(--ease-out);
}
.nms-btn:hover { transform: translateY(-1px); text-decoration: none; }
.nms-btn--sm { height: 36px; padding: 0 14px; font-size: .875rem; border-radius: var(--radius-sm); }
.nms-btn--md { height: 46px; padding: 0 20px; font-size: 1rem; border-radius: var(--radius-md); }
.nms-btn--lg { height: 54px; padding: 0 28px; font-size: 1.0625rem; border-radius: var(--radius-lg); }
.nms-btn--block { width: 100%; }
.nms-btn--primary { background: var(--orange-500); color: #fff; box-shadow: var(--shadow-sm); }
.nms-btn--primary:hover { background: var(--orange-600); color: #fff; box-shadow: var(--shadow-primary); }
.nms-btn--primary:active { background: var(--orange-700); }
.nms-btn--secondary { background: var(--greige-300); color: var(--brown-900); }
.nms-btn--secondary:hover { background: var(--greige-400); color: var(--brown-900); }
.nms-btn--outline { background: transparent; color: var(--orange-600); border: 1.5px solid var(--orange-500); }
.nms-btn--outline:hover { background: var(--orange-50); color: var(--orange-600); }
.nms-btn--ghost { background: transparent; color: var(--orange-600); }
.nms-btn--ghost:hover { background: var(--orange-50); }
.nms-btn--dark { background: var(--brown-900); color: var(--cream-200); }
.nms-btn--dark:hover { background: var(--brown-800); color: var(--cream-200); }
.nms-btn--on-dark { background: rgba(255,255,255,0.1); color: #fff; border: 1px solid rgba(255,255,255,0.25); }
.nms-btn--on-dark:hover { background: rgba(255,255,255,0.16); color: #fff; }
.nms-btn [data-lucide] { width: 1em; height: 1em; }

/* ---- Cards ---- */
.nms-card {
  border-radius: var(--radius-lg); padding: 32px;
  background: var(--surface-card); color: var(--text-primary);
  border: 1px solid var(--border-subtle); box-shadow: var(--shadow-sm);
  transition: transform .2s var(--ease-out), box-shadow .2s var(--ease-out);
}
.nms-card--pad-md { padding: 24px; }
.nms-card--pad-sm { padding: 16px; }
.nms-card--muted  { background: var(--surface-muted); border-color: transparent; box-shadow: none; }
.nms-card--dark   { background: var(--brown-900); color: var(--text-on-dark); border-color: transparent; box-shadow: var(--shadow-md); }
.nms-card--outline{ background: transparent; border: 1.5px solid var(--border-default); box-shadow: none; }
.nms-card--glass  { background: rgba(255,255,255,0.06); color: var(--text-on-dark); border: 1px solid rgba(255,255,255,0.14); box-shadow: none; }
.nms-card--interactive { cursor: pointer; }
.nms-card--interactive:hover { transform: translateY(-3px); box-shadow: var(--shadow-lg); }

/* ---- Badge ---- */
.nms-badge {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 11px; border-radius: var(--radius-pill);
  font-size: .8125rem; font-weight: 600; line-height: 1.4; white-space: nowrap;
  background: var(--greige-300); color: var(--brown-700);
}
.nms-badge--primary { background: var(--orange-100); color: var(--orange-700); }
.nms-badge--success { background: var(--color-success-soft); color: var(--color-success); }
.nms-badge--warning { background: var(--color-warning-soft); color: #9a5e00; }
.nms-badge--danger  { background: var(--color-danger-soft); color: var(--color-danger); }
.nms-badge--info    { background: var(--color-info-soft); color: var(--color-info); }
.nms-badge .dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }

/* ---- Tag ---- */
.nms-tag {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 6px 13px; border-radius: var(--radius-pill);
  font-size: .875rem; font-weight: 500; background: #fff;
  color: var(--text-secondary); border: 1px solid var(--border-default);
}
.nms-tag [data-lucide] { width: 14px; height: 14px; color: var(--orange-500); }

/* ---- Stat ---- */
.nms-stat { display: flex; flex-direction: column; gap: 4px; }
.nms-stat__value {
  font-size: clamp(2.4rem, 4vw, 3.25rem); font-weight: 800;
  letter-spacing: -0.03em; line-height: 1; color: var(--orange-500);
  font-variant-numeric: tabular-nums;
}
.nms-stat__label { font-size: .9375rem; color: var(--text-muted); line-height: 1.4; margin-top: 6px; }
.nms-stat.on-dark .nms-stat__value { color: #fff; }
.nms-stat.on-dark .nms-stat__label { color: rgba(248,245,238,0.75); }
.nms-stat__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: var(--radius-md);
  background: var(--orange-100); color: var(--orange-500); margin-bottom: 8px;
}
.nms-stat.on-dark .nms-stat__icon { background: rgba(236,72,1,0.18); }

/* ---- Avatar ---- */
.nms-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 50%; background: var(--orange-100); color: var(--orange-700);
  font-weight: 700; flex: none;
}
.nms-avatar--lg { width: 56px; height: 56px; font-size: 20px; }
.nms-avatar img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; }

/* ---- Icon chip ---- */
.nms-iconchip {
  display: inline-flex; align-items: center; justify-content: center;
  width: 46px; height: 46px; border-radius: var(--radius-md);
  background: var(--orange-100); color: var(--orange-600); flex: none;
}
.nms-iconchip--lg { width: 52px; height: 52px; }
.nms-iconchip--amber { background: var(--gradient-amber); color: var(--orange-700); }

/* ---- Accordion ---- */
.nms-accordion { display: flex; flex-direction: column; gap: 12px; }
.nms-accordion__item {
  background: var(--surface-card); border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg); overflow: hidden;
}
.nms-accordion__item.is-open { box-shadow: var(--shadow-sm); }
.nms-accordion__btn {
  width: 100%; display: flex; align-items: center; gap: 16px;
  padding: 18px 22px; background: transparent; border: none; cursor: pointer;
  text-align: left; font-size: 1.0625rem; font-weight: 600; color: var(--text-primary);
}
.nms-accordion__num { font-family: var(--font-mono); font-size: .8125rem; color: var(--orange-500); font-weight: 700; }
.nms-accordion__q { flex: 1; }
.nms-accordion__icon { display: inline-flex; color: var(--orange-500); transition: transform .2s var(--ease-out); }
.nms-accordion__item.is-open .nms-accordion__icon { transform: rotate(45deg); }
.nms-accordion__panel { display: grid; grid-template-rows: 0fr; transition: grid-template-rows .2s var(--ease-out); }
.nms-accordion__item.is-open .nms-accordion__panel { grid-template-rows: 1fr; }
.nms-accordion__panel > div { overflow: hidden; }
.nms-accordion__body { padding: 0 22px 20px 60px; color: var(--text-secondary); line-height: 1.6; }

/* ---- Form fields ---- */
.nms-field { display: flex; flex-direction: column; gap: 6px; }
.nms-field__label { font-size: .875rem; font-weight: 600; color: var(--text-secondary); }
.nms-input, .nms-textarea {
  font-family: var(--font-sans); font-size: 1rem; color: var(--text-primary);
  background: #fff; border: 1.5px solid var(--border-default);
  border-radius: var(--radius-md); outline: none; line-height: 1.5;
  transition: border-color .12s, box-shadow .12s; width: 100%;
}
.nms-input { height: 46px; padding: 0 14px; }
.nms-textarea { padding: 12px 14px; resize: vertical; }
.nms-input:focus, .nms-textarea:focus { border-color: var(--orange-500); box-shadow: 0 0 0 4px var(--focus-ring); }
.nms-form-note { font-size: .8125rem; color: var(--text-muted); text-align: center; }

/* ============================================================
   Nav
   ============================================================ */
.nms-nav {
  position: sticky; top: 0; z-index: 50; background: transparent;
  border-bottom: 1px solid transparent;
  transition: background .2s, border-color .2s, backdrop-filter .2s;
}
.nms-nav.is-scrolled {
  background: rgba(248,245,238,0.85); backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--border-subtle);
}
.nms-nav__inner { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.nms-nav__links { display: flex; align-items: center; gap: 4px; }
.nms-navlink {
  font-family: var(--font-sans); font-size: .9375rem; font-weight: 500;
  color: var(--text-secondary); padding: 8px 12px; border-radius: var(--radius-sm);
  text-decoration: none;
}
.nms-navlink:hover { color: var(--orange-600); text-decoration: none; }
.nms-navlink.is-active { font-weight: 700; color: var(--orange-600); }
.nms-nav__toggle {
  display: none; width: 44px; height: 44px; border: 1px solid var(--border-subtle);
  background: var(--surface-card); border-radius: var(--radius-md); cursor: pointer;
  align-items: center; justify-content: center; color: var(--brown-900);
}
.nms-nav__mobile { display: none; }

/* ============================================================
   Page hero band (detail pages)
   ============================================================ */
.nms-pagehero {
  position: relative; overflow: hidden; background: var(--cream-200);
  border-bottom: 1px solid var(--border-subtle);
}
.nms-pagehero__glow {
  position: absolute; top: -200px; right: -120px; width: 560px; height: 560px;
  border-radius: 50%; pointer-events: none;
  background: radial-gradient(circle, var(--glow-1, rgba(244,173,104,0.5)), var(--glow-2, rgba(236,72,1,0.08)) 55%, transparent 72%);
}
.nms-pagehero__inner { position: relative; padding: 56px 0; }
.nms-breadcrumb { display: flex; align-items: center; gap: 8px; font-size: .875rem; color: var(--text-muted); margin-bottom: 18px; }
.nms-breadcrumb a { color: var(--text-muted); text-decoration: none; }
.nms-breadcrumb [data-lucide] { width: 15px; height: 15px; color: var(--brown-400); }
.nms-breadcrumb .current { color: var(--text-secondary); font-weight: 600; }
.nms-pagehero__head { display: flex; flex-direction: column; gap: 16px; max-width: 800px; }
.nms-pagehero h1 {
  font-size: clamp(2.2rem, 4.6vw, 3.5rem); font-weight: 800;
  letter-spacing: -0.03em; line-height: 1.05; color: var(--text-primary);
}
.nms-pagehero__lead { font-size: 1.1875rem; line-height: 1.6; color: var(--text-secondary); }

/* ============================================================
   Footer
   ============================================================ */
.nms-footer { background: var(--brown-900); color: var(--text-on-dark); padding-top: 72px; }
.nms-footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 40px; padding-bottom: 56px; border-bottom: 1px solid rgba(255,255,255,0.12); }
.nms-footer__brand { display: flex; flex-direction: column; gap: 16px; max-width: 320px; }
.nms-footer__blurb { font-size: .9375rem; line-height: 1.6; color: rgba(248,245,238,0.7); }
.nms-footer__socials { display: flex; gap: 10px; margin-top: 4px; }
.nms-social {
  width: 38px; height: 38px; border-radius: 50%; display: inline-flex;
  align-items: center; justify-content: center; background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.16); transition: background .2s, border-color .2s;
}
.nms-social:hover { background: var(--orange-500); border-color: var(--orange-500); }
.nms-social [data-lucide], .nms-social svg { width: 16px; height: 16px; color: #f8f5ee; }
.nms-footer__col { display: flex; flex-direction: column; gap: 14px; }
.nms-footer__col-head { font-size: .8125rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; color: var(--orange-300); }
.nms-footer__col a { font-size: .9375rem; color: rgba(248,245,238,0.72); text-decoration: none; }
.nms-footer__col a:hover { color: #fff; text-decoration: none; }
.nms-footer__bottom { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; padding: 24px 0 32px; }
.nms-footer__copy { font-size: .875rem; color: rgba(248,245,238,0.55); }
.nms-footer__legal { display: flex; gap: 20px; flex-wrap: wrap; }
.nms-footer__legal a { font-size: .875rem; color: rgba(248,245,238,0.72); text-decoration: none; }
.nms-footer__legal a:hover { color: #fff; }
.nms-footer__theme { display: inline-flex; align-items: center; gap: 7px; color: rgba(248,245,238,0.72); }
.nms-footer__theme [data-lucide] { width: 15px; height: 15px; }
.nms-footer__theme select { background: rgba(255,255,255,0.08); color: var(--cream-200); border: 1px solid rgba(255,255,255,0.18); border-radius: var(--radius-sm); padding: 5px 9px; font-family: var(--font-sans); font-size: .8125rem; cursor: pointer; }
.nms-footer__theme select option { color: #111; }

/* ============================================================
   Hero section
   ============================================================ */
.nms-hero { position: relative; overflow: hidden; background: var(--cream-200); }
.nms-hero__glow {
  position: absolute; top: -160px; right: -120px; width: 620px; height: 620px;
  border-radius: 50%; filter: blur(8px); pointer-events: none;
  background: radial-gradient(circle, var(--glow-1, rgba(244,173,104,0.55)), var(--glow-2, rgba(236,72,1,0.10)) 55%, transparent 72%);
}
.nms-hero__inner { position: relative; padding: 72px 0 88px; }
.nms-hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
.nms-hero__col { display: flex; flex-direction: column; gap: 26px; }
.nms-hero h1 {
  font-size: clamp(2.6rem, 5.2vw, 4.25rem); font-weight: 800;
  letter-spacing: -0.035em; line-height: 1.02; color: var(--text-primary);
}
.nms-hero h1 .hl { color: var(--orange-500); }
.nms-hero__lead { font-size: 1.1875rem; line-height: 1.6; color: var(--text-secondary); max-width: 540px; }
.nms-hero__cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 4px; }
.nms-hero__trust { display: flex; align-items: center; gap: 10px; margin-top: 8px; color: var(--text-muted); font-size: .875rem; }
.nms-hero__trust [data-lucide] { width: 18px; height: 18px; color: var(--color-success); }
.nms-hero__aside { display: flex; flex-direction: column; gap: 18px; }
.nms-hero__media {
  position: relative; height: 240px; border-radius: 24px; overflow: hidden;
  box-shadow: var(--shadow-lg); background: var(--gradient-warm);
}
.nms-hero__media::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, transparent 55%, rgba(51,0,15,0.28)); }
.nms-hero__media-cap { position: absolute; left: 16px; bottom: 14px; z-index: 1; display: inline-flex; align-items: center; gap: 8px; font-size: .8125rem; font-weight: 600; color: #fff; }
.nms-hero__media-cap .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--orange-400); display: inline-block; }

/* Hero talent-flow card */
.nms-flow__head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.nms-flow__title { font-weight: 700; font-size: .9375rem; color: var(--text-primary); }
.nms-flow__grid { display: grid; grid-template-columns: 1fr auto 1fr; gap: 14px; align-items: center; }
.nms-flow__coltitle { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-muted); }
.nms-flow__col { display: flex; flex-direction: column; gap: 8px; }
.nms-flow__chip { padding: 10px 12px; background: var(--cream-200); border-radius: var(--radius-sm); font-size: .875rem; font-weight: 600; color: var(--text-primary); }
.nms-flow__chip--deploy { background: var(--orange-500); color: #fff; }
.nms-flow__arrow { display: flex; align-items: center; justify-content: center; color: var(--orange-500); }
.nms-flow__arrow [data-lucide] { width: 22px; height: 22px; }
.nms-flow__stats { display: flex; gap: 16px; margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--border-subtle); }
.nms-flow__stats .nms-stat { flex: 1; }

/* ============================================================
   Approach section
   ============================================================ */
.nms-approach-grid { display: grid; grid-template-columns: 0.8fr 2.4fr 0.8fr; gap: 20px; align-items: stretch; }
.nms-approach__side { display: flex; flex-direction: column; justify-content: center; gap: 8px; }
.nms-approach__side--deploy { background: var(--orange-100); }
.nms-approach__kicker { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--orange-600); }
.nms-approach__lead { font-size: 1.25rem; font-weight: 700; color: var(--text-primary); }
.nms-approach__note { font-size: .875rem; color: var(--text-muted); }
.nms-approach__side--deploy .nms-approach__note { color: var(--brown-700); }
.nms-approach__core-eyebrow { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--orange-300); }
.nms-approach__steps { display: grid; grid-template-columns: repeat(3,1fr); gap: 14px; margin-top: 18px; }
.nms-approach__step { display: flex; flex-direction: column; gap: 8px; padding: 16px; background: rgba(255,255,255,0.06); border-radius: var(--radius-md); border: 1px solid rgba(255,255,255,0.1); }
.nms-approach__step-top { display: flex; align-items: center; justify-content: space-between; }
.nms-approach__step-top [data-lucide] { color: var(--orange-300); width: 20px; height: 20px; }
.nms-approach__step-n { font-family: var(--font-mono); font-size: .75rem; color: rgba(248,245,238,0.5); }
.nms-approach__step-t { font-size: .9375rem; font-weight: 600; color: var(--cream-200); }

/* ============================================================
   Platform layers
   ============================================================ */
.nms-layer { display: flex; flex-direction: column; gap: 14px; }
.nms-layer__top { display: flex; align-items: center; justify-content: space-between; }
.nms-layer__n { font-family: var(--font-mono); font-size: .8125rem; color: var(--text-muted); }
.nms-layer__title { font-size: 1.125rem; font-weight: 700; color: var(--text-primary); }
.nms-layer__items { display: flex; flex-direction: column; gap: 9px; margin-top: 2px; }
.nms-layer__item { display: flex; align-items: flex-start; gap: 8px; font-size: .875rem; color: var(--text-secondary); }
.nms-layer__item [data-lucide] { width: 15px; height: 15px; color: var(--orange-500); margin-top: 2px; flex: none; }

/* ============================================================
   Value metrics (dark)
   ============================================================ */
.nms-value__desc { font-size: .875rem; color: rgba(248,245,238,0.6); margin-top: 8px; line-height: 1.5; }
.nms-value__cta { display: flex; flex-direction: column; justify-content: center; gap: 14px; background: var(--gradient-ember); border: none; }
.nms-value__cta-text { font-size: 1.25rem; font-weight: 700; color: #fff; line-height: 1.3; }

/* ============================================================
   Why different (comparison)
   ============================================================ */
.nms-compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; max-width: 920px; margin: 0 auto; }
.nms-compare__title { font-size: 1rem; font-weight: 700; }
.nms-compare__title--trad { color: var(--text-muted); }
.nms-compare__title--nms { color: var(--orange-600); }
.nms-compare__list { display: flex; flex-direction: column; gap: 12px; margin-top: 18px; }
.nms-compare__row { display: flex; align-items: center; gap: 10px; font-size: .9375rem; }
.nms-compare__row--trad { color: var(--text-muted); }
.nms-compare__row--nms { color: var(--text-primary); font-weight: 500; }
.nms-compare__row [data-lucide] { width: 18px; height: 18px; flex: none; }
.nms-compare__row--trad [data-lucide] { color: var(--brown-400); }
.nms-compare__row--nms [data-lucide] { color: var(--color-success); }
.nms-card--traditional { background: rgba(255,255,255,0.5); }
.nms-card--nms-highlight { border: 1.5px solid var(--orange-300); box-shadow: var(--shadow-md); }

/* ============================================================
   Models accordion layout
   ============================================================ */
.nms-models-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 48px; align-items: start; }
.nms-models-grid.is-single { grid-template-columns: 1fr; }
.nms-models__head { position: sticky; top: 96px; }

/* ============================================================
   Future roles
   ============================================================ */
.nms-role { display: flex; align-items: center; gap: 16px; }
.nms-role__meta { display: flex; flex-direction: column; gap: 3px; }
.nms-role__kicker { font-family: var(--font-mono); font-size: .6875rem; letter-spacing: 0.08em; color: var(--text-muted); text-transform: uppercase; }
.nms-role__name { font-size: 1.0625rem; font-weight: 700; color: var(--text-primary); }

/* ============================================================
   Team
   ============================================================ */
.nms-team-card { display: flex; flex-direction: column; gap: 14px; }
.nms-team-card__top { display: flex; align-items: center; justify-content: space-between; }
.nms-team-card__ln {
  display: inline-flex; align-items: center; justify-content: center;
  width: 40px; height: 40px; border-radius: var(--radius-md);
  background: var(--greige-300); color: var(--brown-700); text-decoration: none;
}
.nms-team-card__name { font-size: 1.125rem; font-weight: 700; color: var(--text-primary); }
.nms-team-card__role { font-size: .875rem; font-weight: 600; color: var(--orange-600); }
.nms-team-card__bio { font-size: .9375rem; line-height: 1.6; color: var(--text-secondary); flex: 1; }
.nms-team-card__link { display: inline-flex; align-items: center; gap: 8px; font-size: .875rem; font-weight: 600; color: var(--orange-600); text-decoration: none; }
.nms-team-card__link svg { width: 15px; height: 15px; }

/* ============================================================
   Contact CTA
   ============================================================ */
.nms-audience { display: flex; flex-direction: column; gap: 14px; }
.nms-audience__title { font-size: 1.1875rem; font-weight: 700; color: var(--text-primary); }
.nms-audience__desc { font-size: .9375rem; line-height: 1.6; color: var(--text-secondary); flex: 1; }
.nms-audience__link { display: inline-flex; align-items: center; gap: 8px; font-size: .9375rem; font-weight: 600; color: var(--orange-600); }
.nms-audience__link [data-lucide] { width: 16px; height: 16px; }
.nms-cta-band { margin-top: 24px; display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 20px; background: var(--gradient-ember); }
.nms-cta-band__title { font-size: 1.5rem; font-weight: 800; color: #fff; letter-spacing: -0.02em; }
.nms-cta-band__sub { font-size: 1rem; color: rgba(255,255,255,0.85); margin-top: 4px; }

/* ============================================================
   About intro
   ============================================================ */
.nms-about__intro { max-width: 760px; margin-bottom: 48px; font-size: 1.25rem; line-height: 1.65; color: var(--text-secondary); }
.nms-about__intro strong { color: var(--text-primary); }
.nms-about__pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; margin-bottom: 20px; }
.nms-pillar { display: flex; flex-direction: column; gap: 12px; }
.nms-pillar__title { font-size: 1.25rem; font-weight: 800; letter-spacing: -0.02em; color: var(--text-primary); }
.nms-pillar__body { font-size: 1rem; line-height: 1.6; color: var(--text-secondary); }
.nms-about__markets { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.nms-about__market-label { font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--orange-600); }
.nms-about__tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 12px; }

/* ============================================================
   Contact form page
   ============================================================ */
.nms-contact-grid { display: grid; grid-template-columns: 0.9fr 1.1fr; gap: 48px; align-items: start; }
.nms-reach { display: flex; flex-direction: column; gap: 20px; }
.nms-reach__item { display: flex; align-items: center; gap: 14px; }
.nms-reach__label { font-size: .8125rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted); }
.nms-reach__value { font-size: 1.0625rem; font-weight: 600; color: var(--text-primary); }
.nms-reach__list { display: flex; flex-direction: column; gap: 10px; }
.nms-reach__list-row { display: flex; align-items: center; gap: 10px; font-size: .9375rem; color: var(--text-secondary); }
.nms-reach__list-row [data-lucide] { width: 16px; height: 16px; color: var(--color-success); }
.nms-form { display: flex; flex-direction: column; gap: 16px; }
.nms-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.nms-form__success { padding: 32px 8px; text-align: center; display: flex; flex-direction: column; align-items: center; gap: 12px; }
.nms-form__success-icon { display: inline-flex; align-items: center; justify-content: center; width: 64px; height: 64px; border-radius: 50%; background: var(--color-success-soft); color: var(--color-success); }
.nms-form__success h3 { font-size: 1.375rem; font-weight: 800; }

/* ============================================================
   Legal pages
   ============================================================ */
.nms-legal { max-width: 760px; display: flex; flex-direction: column; gap: 28px; }
.nms-legal__notice { font-size: .875rem; color: var(--text-muted); line-height: 1.6; }
.nms-legal__clause { display: flex; flex-direction: column; gap: 8px; }
.nms-legal__clause h2 { font-size: 1.375rem; font-weight: 800; letter-spacing: -0.02em; color: var(--text-primary); }
.nms-legal__clause p { font-size: 1rem; line-height: 1.7; color: var(--text-secondary); }

/* ---- Rich text ---- */
.nms-richtext { max-width: 760px; }
.nms-richtext h2 { font-size: 1.75rem; margin: 1.5em 0 .5em; }
.nms-richtext h3 { font-size: 1.35rem; margin: 1.2em 0 .4em; }
.nms-richtext p { margin: 0 0 1em; font-size: 1.0625rem; line-height: 1.7; color: var(--text-secondary); }
.nms-richtext ul { padding-left: 1.2em; }

/* ============================================================
   Partner modal
   ============================================================ */
.nms-modal { position: fixed; inset: 0; z-index: 100; background: rgba(51,0,15,0.55); backdrop-filter: blur(4px); display: none; align-items: center; justify-content: center; padding: 20px; }
.nms-modal.is-open { display: flex; }
.nms-modal__dialog { width: 100%; max-width: 520px; background: var(--surface-card); border-radius: var(--radius-xl); box-shadow: var(--shadow-xl); overflow: hidden; }
.nms-modal__head { padding: 24px 28px; background: var(--gradient-amber); display: flex; align-items: center; justify-content: space-between; }
.nms-modal__title { font-size: 1.25rem; font-weight: 800; color: var(--brown-900); margin-top: 8px; letter-spacing: -0.02em; }
.nms-modal__close { width: 38px; height: 38px; border-radius: 50%; border: none; background: rgba(255,255,255,0.6); cursor: pointer; display: inline-flex; align-items: center; justify-content: center; color: var(--brown-900); }
.nms-modal__body { padding: 28px; }

/* Shared grids */
.nms-grid-3 { display: grid; grid-template-columns: repeat(3,1fr); gap: 20px; }
.nms-grid-3.gap-sm { gap: 18px; }
.nms-grid-4 { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; }
.nms-stack { display: flex; flex-direction: column; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 980px) {
  .nms-desktop-nav { display: none !important; }
  .nms-nav__toggle { display: inline-flex; }
  .nms-hero-grid, .nms-models-grid { grid-template-columns: 1fr !important; }
  .nms-approach-grid, .nms-contact-grid { grid-template-columns: 1fr !important; }
  .nms-grid-4 { grid-template-columns: 1fr 1fr !important; }
  .nms-footer-grid { grid-template-columns: 1fr 1fr !important; }
  .nms-models__head { position: static; }
}
@media (max-width: 640px) {
  .nms-grid-3, .nms-grid-4, .nms-compare-grid, .nms-footer-grid,
  .nms-about__pillars, .nms-about__markets, .nms-form__row,
  .nms-approach__steps { grid-template-columns: 1fr !important; }
  .nms-cta-band { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   Mobile nav drawer
   ============================================================ */
.nms-nav__mobile.is-open {
  display: block; position: fixed; inset: 72px 0 0; z-index: 45;
  background: rgba(248,245,238,0.97); backdrop-filter: blur(8px); padding: 24px var(--container-pad);
}
.nms-nav__mobile a { display: block; padding: 14px 0; font-size: 1.25rem; font-weight: 600; color: var(--text-primary); border-bottom: 1px solid var(--border-subtle); text-decoration: none; }

/* ============================================================
   Animations (respect reduced motion)
   ============================================================ */
@keyframes nms-fade-up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
@keyframes nms-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }
@keyframes nms-glow { from { transform: scale(1); opacity: 0.75; } to { transform: scale(1.15); opacity: 1; } }
@keyframes nms-pulse { 0%, 100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.35; transform: scale(0.82); } }
@keyframes nms-reveal { from { clip-path: inset(0 100% 0 0); } to { clip-path: inset(0 0 0 0); } }
@media (prefers-reduced-motion: no-preference) {
  .nms-fade-up { opacity: 0; animation: nms-fade-up .7s var(--ease-out) forwards; }
  .nms-d1 { animation-delay: .08s; } .nms-d2 { animation-delay: .18s; }
  .nms-d3 { animation-delay: .28s; } .nms-d4 { animation-delay: .40s; }
  .nms-glow-anim { animation: nms-glow 12s ease-in-out infinite alternate; }
  .nms-float-anim { animation: nms-float 7s ease-in-out infinite; }
  .nms-pulse-anim { animation: nms-pulse 1.8s ease-in-out infinite; }
  .nms-card-in { opacity: 0; animation: nms-fade-up .8s var(--ease-out) .25s forwards; }
  .nms-reveal { animation: nms-reveal .9s var(--ease-out) .3s both; }
}
