:root {
  --ndppc-primary: #1d4b39;
  --ndppc-primary-dark: #122c22;
  --ndppc-accent: #8c6d31;
  --ndppc-accent-soft: #ece3cf;
  --ndppc-surface: #f7f4ed;
  --ndppc-surface-alt: #ece7dc;
  --ndppc-card: rgba(255, 255, 255, 0.98);
  --ndppc-line: rgba(18, 44, 34, 0.11);
  --ndppc-copy: #23372d;
  --ndppc-copy-soft: #5f6e66;
  --ndppc-shadow: 0 18px 40px rgba(18, 44, 34, 0.08);
  --ndppc-radius: 16px;
  --ndppc-radius-sm: 10px;
  --ndppc-max: 1240px;
  --ndppc-header-offset: 164px;
}

/* Final Facility Systems Redesign */
body[data-page="infra"] .ndppc-infra-facility-band,
body[data-page="infra"] .ndppc-infra-ops-band,
body[data-page="infra"] .ndppc-infra-capability-band,
body[data-page="infra"] .ndppc-infra-browser-band-refresh {
  padding: 44px 0;
}

body[data-page="infra"] .ndppc-infra-facility-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.03fr) minmax(320px, 0.97fr);
  gap: 1.6rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-facility-copy,
body[data-page="infra"] .ndppc-infra-browser-intro,
body[data-page="infra"] .ndppc-infra-metric-card,
body[data-page="infra"] .ndppc-infra-ops-card,
body[data-page="infra"] .ndppc-infra-capability-card,
body[data-page="infra"] .ndppc-infra-browser-shell,
body[data-page="infra"] .ndppc-infra-browser-detail {
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 18px 34px rgba(20, 53, 38, 0.08);
}

body[data-page="infra"] .ndppc-infra-facility-copy {
  padding: 1.55rem 1.6rem;
  border-radius: 24px;
}

body[data-page="infra"] .ndppc-infra-facility-copy h2,
body[data-page="infra"] .ndppc-infra-section-head h2 {
  margin: 0 0 1rem;
  font-size: clamp(1.6rem, 2.15vw, 2.2rem);
  line-height: 1.14;
  color: var(--ndppc-primary-dark);
}

body[data-page="infra"] .ndppc-infra-facility-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-section-head .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-ops-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-capability-card .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-browser-intro .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-stage-text .ndppc-card-copy {
  color: var(--ndppc-copy);
  line-height: 1.78;
}

body[data-page="infra"] .ndppc-infra-keyline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin: 1.25rem 0 1.35rem;
}

body[data-page="infra"] .ndppc-infra-keyline span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.5rem 0.95rem;
  border-radius: 999px;
  background: var(--ndppc-accent-soft);
  color: #7a5a21;
  font-size: 0.92rem;
  font-weight: 700;
}

body[data-page="infra"] .ndppc-infra-facility-visual {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.72fr);
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-facility-main,
body[data-page="infra"] .ndppc-infra-facility-secondary {
  margin: 0;
  border-radius: 24px;
  overflow: hidden;
  min-height: 100%;
}

body[data-page="infra"] .ndppc-infra-facility-main img,
body[data-page="infra"] .ndppc-infra-facility-secondary img {
  width: 100%;
  height: 100%;
  min-height: 240px;
  object-fit: cover;
  display: block;
}

body[data-page="infra"] .ndppc-infra-facility-rail {
  display: grid;
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="infra"] .ndppc-infra-metric-card {
  padding: 1rem 1rem 0.95rem;
  border-radius: 20px;
}

body[data-page="infra"] .ndppc-infra-metric-card strong {
  display: block;
  margin-bottom: 0.3rem;
  font-size: 2rem;
  line-height: 1;
  color: var(--ndppc-primary-dark);
}

body[data-page="infra"] .ndppc-infra-metric-card h3 {
  margin: 0 0 0.45rem;
  font-size: 0.98rem;
  color: #7a5a21;
}

body[data-page="infra"] .ndppc-infra-section-head {
  margin-bottom: 1.25rem;
  max-width: 76ch;
}

body[data-page="infra"] .ndppc-infra-ops-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-ops-card {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 1rem;
  padding: 1.2rem;
  border-radius: 22px;
}

body[data-page="infra"] .ndppc-infra-ops-step {
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

body[data-page="infra"] .ndppc-infra-ops-number {
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: linear-gradient(180deg, #173d2e 0%, #214b39 100%);
  color: #fff;
  font-size: 1.2rem;
  font-weight: 800;
}

body[data-page="infra"] .ndppc-infra-ops-copy h3,
body[data-page="infra"] .ndppc-infra-capability-card h3,
body[data-page="infra"] .ndppc-infra-stage-copy h3 {
  margin: 0 0 0.6rem;
  font-size: 1.2rem;
  line-height: 1.25;
  color: var(--ndppc-primary-dark);
}

body[data-page="infra"] .ndppc-infra-ops-points,
body[data-page="infra"] .ndppc-infra-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.9rem;
}

body[data-page="infra"] .ndppc-infra-capability-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-capability-card {
  padding: 1.2rem 1.2rem 1.1rem;
  border-radius: 22px;
}

body[data-page="infra"] .ndppc-infra-capability-list {
  margin: 0.95rem 0 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.42rem;
}

body[data-page="infra"] .ndppc-infra-capability-list li {
  color: var(--ndppc-copy);
  line-height: 1.52;
}

body[data-page="infra"] .ndppc-infra-browser-refresh-shell {
  display: grid;
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-browser-intro {
  padding: 1rem 1.2rem;
  border-radius: 20px;
}

body[data-page="infra"] .ndppc-infra-browser-shell {
  display: grid;
  grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
  gap: 1rem;
  padding: 1rem;
  border-radius: 24px;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
  display: grid;
  gap: 0.8rem;
  align-content: start;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  display: grid;
  gap: 0.3rem;
  justify-items: start;
  padding: 1rem 1rem 0.95rem;
  border-radius: 18px;
  text-align: left;
  background: rgba(255, 255, 255, 0.9);
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn strong {
  font-size: 0.98rem;
  line-height: 1.3;
  color: var(--ndppc-primary-dark);
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn span {
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--ndppc-copy-soft);
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active {
  background: linear-gradient(180deg, rgba(22, 61, 46, 0.98), rgba(30, 71, 55, 0.98));
  border-color: rgba(22, 61, 46, 0.98);
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active strong,
body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active span {
  color: rgba(255, 255, 255, 0.95);
}

body[data-page="infra"] .ndppc-infra-browser-detail {
  padding: 0;
  border-radius: 22px;
  overflow: hidden;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-panel {
  display: grid;
  grid-template-columns: minmax(240px, 0.8fr) minmax(0, 1.2fr);
  min-height: 100%;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-media {
  min-height: 100%;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-media img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  display: block;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-copy {
  padding: 1.35rem 1.4rem 1.3rem;
  background: rgba(255, 255, 255, 0.98);
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.8rem;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-kicker {
  color: #7a5a21;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-points-wrap {
  margin-top: 1rem;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-points-wrap strong {
  display: block;
  margin-bottom: 0.65rem;
  color: var(--ndppc-primary-dark);
  font-size: 0.92rem;
}

@media (max-width: 1199px) {
  body[data-page="infra"] .ndppc-infra-facility-grid,
  body[data-page="infra"] .ndppc-infra-facility-visual,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-panel {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  body[data-page="infra"] .ndppc-infra-facility-band,
  body[data-page="infra"] .ndppc-infra-ops-band,
  body[data-page="infra"] .ndppc-infra-capability-band,
  body[data-page="infra"] .ndppc-infra-browser-band-refresh {
    padding: 32px 0;
  }

  body[data-page="infra"] .ndppc-infra-ops-grid,
  body[data-page="infra"] .ndppc-infra-capability-grid,
  body[data-page="infra"] .ndppc-infra-metric-grid,
  body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-facility-copy,
  body[data-page="infra"] .ndppc-infra-browser-intro,
  body[data-page="infra"] .ndppc-infra-metric-card,
  body[data-page="infra"] .ndppc-infra-ops-card,
  body[data-page="infra"] .ndppc-infra-capability-card,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-browser-detail,
  body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-copy {
    padding: 1rem;
  }

  body[data-page="infra"] .ndppc-infra-facility-copy h2,
  body[data-page="infra"] .ndppc-infra-section-head h2 {
    font-size: 1.58rem;
  }

  body[data-page="infra"] .ndppc-infra-ops-card {
    grid-template-columns: 60px minmax(0, 1fr);
  }

  body[data-page="infra"] .ndppc-infra-ops-number {
    width: 48px;
    height: 48px;
    border-radius: 15px;
    font-size: 1.05rem;
  }

body[data-page="infra"] .ndppc-infra-facility-main img,
body[data-page="infra"] .ndppc-infra-facility-secondary img,
body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-media img {
  min-height: 220px;
}
}

/* Final Notifications Page Redesign */
body[data-page="notifications"] .ndppc-notice-overview-band .container,
body[data-page="notifications"] .ndppc-notice-board-band .container,
body[data-page="notifications"] .ndppc-notice-doc-band .container {
  max-width: 1320px;
}

body[data-page="notifications"] .banner.ndppc-notice-banner {
  padding-top: 0;
  margin-top: 0;
  background: transparent;
}

body[data-page="notifications"] .banner.ndppc-notice-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="notifications"] .banner_content.ndppc-notice-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="notifications"] .ndppc-notice-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="notifications"] .ndppc-notice-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="notifications"] .ndppc-notice-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.82) 58%, rgba(250, 247, 240, 0.64) 100%);
  z-index: 1;
}

body[data-page="notifications"] .ndppc-notice-banner-copy {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: center;
  gap: 0.9rem;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="notifications"] .ndppc-notice-banner-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="notifications"] .ndppc-notice-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="notifications"] .ndppc-notice-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.08;
}

body[data-page="notifications"] .ndppc-notice-overview-band,
body[data-page="notifications"] .ndppc-notice-board-band,
body[data-page="notifications"] .ndppc-notice-doc-band {
  padding-top: 28px;
  padding-bottom: 28px;
}

body[data-page="notifications"] .ndppc-notice-overview-band {
  background:
    linear-gradient(180deg, rgba(20, 53, 38, 0.04), rgba(20, 53, 38, 0)),
    linear-gradient(135deg, rgba(184, 146, 66, 0.08), rgba(255, 255, 255, 0.72));
}

body[data-page="notifications"] .ndppc-notice-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.8fr);
  gap: 1.4rem;
  align-items: start;
}

body[data-page="notifications"] .ndppc-notice-overview-copy {
  display: grid;
  gap: 1rem;
}

body[data-page="notifications"] .ndppc-notice-overview-copy h2,
body[data-page="notifications"] .ndppc-notice-board-band .ndppc-section-copy h3,
body[data-page="notifications"] .ndppc-notice-doc-band .ndppc-section-copy h3 {
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
}

body[data-page="notifications"] .ndppc-notice-overview-copy .ndppc-card-copy {
  margin: 0;
  text-align: justify;
  line-height: 1.85;
}

body[data-page="notifications"] .ndppc-notice-metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.95rem;
}

body[data-page="notifications"] .ndppc-notice-metric-card {
  display: grid;
  gap: 0.35rem;
  align-content: center;
  min-height: 118px;
  padding: 1rem 1.05rem;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: rgba(255, 255, 255, 0.96);
}

body[data-page="notifications"] .ndppc-notice-metric-card strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.1vw, 2.3rem);
  line-height: 1;
}

body[data-page="notifications"] .ndppc-notice-metric-card span {
  color: rgba(20, 53, 38, 0.82);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

body[data-page="notifications"] .ndppc-notice-board-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 1.25rem;
}

body[data-page="notifications"] .ndppc-notice-feature-card,
body[data-page="notifications"] .ndppc-notice-stack-item {
  display: grid;
  gap: 0.8rem;
  padding: 1.2rem 1.25rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.96);
}

body[data-page="notifications"] .ndppc-notice-feature-card {
  align-content: start;
  min-height: 100%;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 235, 0.94));
}

body[data-page="notifications"] .ndppc-notice-feature-card h3,
body[data-page="notifications"] .ndppc-notice-stack-item h4 {
  margin: 0;
  color: var(--ndppc-primary-dark);
}

body[data-page="notifications"] .ndppc-notice-stack {
  display: grid;
  gap: 1rem;
}

body[data-page="notifications"] .ndppc-notice-stack-meta {
  display: flex;
  align-items: center;
  gap: 0.65rem;
}

body[data-page="notifications"] .ndppc-notice-stack-index {
  color: rgba(20, 53, 38, 0.22);
  font-size: 1.35rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="notifications"] .ndppc-notice-feature-card .ndppc-card-copy,
body[data-page="notifications"] .ndppc-notice-stack-item .ndppc-card-copy,
body[data-page="notifications"] .ndppc-notice-doc-band .ndppc-section-copy p {
  margin: 0;
  line-height: 1.8;
}

body[data-page="notifications"] .ndppc-notice-board-band .ndppc-section-bar,
body[data-page="notifications"] .ndppc-notice-doc-band .ndppc-section-bar {
  margin-bottom: 1.15rem;
}

body[data-page="notifications"] .ndppc-notice-doc-band .ndppc-doc-grid {
  margin-top: 0;
}

@media (max-width: 991px) {
  body[data-page="notifications"] .ndppc-notice-banner-frame,
  body[data-page="notifications"] .ndppc-notice-banner-frame img {
    min-height: 102px;
  }

  body[data-page="notifications"] .ndppc-notice-overview-grid,
  body[data-page="notifications"] .ndppc-notice-board-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="notifications"] .ndppc-notice-banner-frame,
  body[data-page="notifications"] .ndppc-notice-banner-frame img {
    min-height: 88px;
  }

  body[data-page="notifications"] .ndppc-notice-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="notifications"] .ndppc-notice-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="notifications"] .ndppc-notice-overview-band,
  body[data-page="notifications"] .ndppc-notice-board-band,
  body[data-page="notifications"] .ndppc-notice-doc-band {
    padding-top: 16px;
    padding-bottom: 16px;
  }

  body[data-page="notifications"] .ndppc-notice-metric-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="notifications"] .ndppc-notice-feature-card,
  body[data-page="notifications"] .ndppc-notice-stack-item,
  body[data-page="notifications"] .ndppc-notice-metric-card {
    padding: 1rem;
  }
}

/* Final Notifications List Layout */
body[data-page="notifications"] .ndppc-notice-list-band {
  padding-top: 26px;
  padding-bottom: 34px;
  background: transparent;
}

body[data-page="notifications"] .ndppc-notice-list-band .container {
  max-width: 1320px;
}

body[data-page="notifications"] .ndppc-notice-list {
  display: grid;
  gap: 1.25rem;
}

body[data-page="notifications"] .ndppc-notice-row {
  display: grid;
  grid-template-columns: 92px minmax(0, 1fr) auto;
  align-items: stretch;
  gap: 1.2rem;
  padding: 1.2rem 1.25rem;
  border: 1px solid rgba(25, 120, 61, 0.55);
  border-left: 4px solid rgba(25, 120, 61, 0.92);
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(249, 247, 241, 0.98));
}

body[data-page="notifications"] .ndppc-notice-row-side {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.45rem;
  min-height: 100%;
  padding: 0.9rem 0.75rem;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(244, 238, 222, 0.88), rgba(237, 244, 236, 0.88));
}

body[data-page="notifications"] .ndppc-notice-row-number {
  color: var(--ndppc-primary-dark);
  font-size: 1.28rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.04em;
}

body[data-page="notifications"] .ndppc-notice-row-side i {
  color: #19783d;
  font-size: 1.2rem;
}

body[data-page="notifications"] .ndppc-notice-row-copy {
  display: grid;
  align-content: center;
  gap: 0.55rem;
}

body[data-page="notifications"] .ndppc-notice-row-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
}

body[data-page="notifications"] .ndppc-notice-status {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0.3rem 0.8rem;
  border-radius: 999px;
  background: rgba(232, 240, 228, 0.96);
  color: #256940;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="notifications"] .ndppc-notice-status-link {
  background: rgba(231, 241, 247, 0.98);
  color: #0f5a79;
}

body[data-page="notifications"] .ndppc-notice-row-copy h3 {
  margin: 0;
  color: #07140f;
  font-size: clamp(1.12rem, 1.45vw, 1.34rem);
  line-height: 1.42;
  font-weight: 700;
}

body[data-page="notifications"] .ndppc-notice-row-copy p {
  margin: 0;
  color: rgba(7, 20, 15, 0.92);
  font-size: clamp(1rem, 1.12vw, 1.1rem);
  line-height: 1.5;
}

body[data-page="notifications"] .ndppc-notice-row-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  align-content: center;
  gap: 0.85rem;
  flex-wrap: wrap;
}

body[data-page="notifications"] .ndppc-notice-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.65rem;
  min-width: 118px;
  min-height: 56px;
  padding: 0.82rem 1.1rem;
  border-radius: 14px;
  background: #0f5a79;
  color: #fff;
  font-size: 0.98rem;
  font-weight: 700;
  text-decoration: none;
  box-shadow: 0 10px 20px rgba(15, 90, 121, 0.12);
}

body[data-page="notifications"] .ndppc-notice-action:hover,
body[data-page="notifications"] .ndppc-notice-action:focus-visible {
  background: #0b4b65;
  color: #fff;
}

body[data-page="notifications"] .ndppc-notice-action i {
  font-size: 1.08rem;
}

@media (max-width: 991px) {
  body[data-page="notifications"] .ndppc-notice-row {
    grid-template-columns: 72px minmax(0, 1fr);
    align-items: start;
  }

  body[data-page="notifications"] .ndppc-notice-row-actions {
    grid-column: 1 / -1;
    justify-content: flex-start;
    padding-left: calc(72px + 1.2rem);
  }
}

@media (max-width: 767px) {
  body[data-page="notifications"] .ndppc-notice-list-band {
    padding-top: 18px;
    padding-bottom: 22px;
  }

  body[data-page="notifications"] .ndppc-notice-list {
    gap: 1.15rem;
  }

  body[data-page="notifications"] .ndppc-notice-row {
    grid-template-columns: 1fr;
    gap: 0.9rem;
    padding: 1rem;
    border-radius: 16px;
  }

  body[data-page="notifications"] .ndppc-notice-row-side {
    grid-auto-flow: column;
    justify-content: start;
    justify-items: start;
    min-height: 0;
    padding: 0.7rem 0.85rem;
  }

  body[data-page="notifications"] .ndppc-notice-row-copy h3 {
    font-size: 1.02rem;
  }

  body[data-page="notifications"] .ndppc-notice-row-copy p {
    font-size: 0.98rem;
  }

  body[data-page="notifications"] .ndppc-notice-row-actions {
    padding-left: 0;
    gap: 0.75rem;
  }

  body[data-page="notifications"] .ndppc-notice-action {
    min-width: 106px;
    min-height: 52px;
    padding: 0.72rem 1rem;
    border-radius: 14px;
  }
}

/* Final Publications Page Redesign */
body[data-page="publications"] .ndppc-publications-overview-band .container,
body[data-page="publications"] .ndppc-publications-record-band .container,
body[data-page="publications"] .ndppc-publications-doc-band .container,
body[data-page="publications"] .ndppc-publications-path-band .container {
  max-width: 1320px;
}

body[data-page="publications"] .banner.ndppc-publications-banner {
  padding-top: 0;
  margin-top: 0;
  background: transparent;
}

body[data-page="publications"] .banner.ndppc-publications-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="publications"] .banner_content.ndppc-publications-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="publications"] .ndppc-publications-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="publications"] .ndppc-publications-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="publications"] .ndppc-publications-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="publications"] .ndppc-publications-banner-copy {
  position: absolute;
  inset: 0;
  display: grid;
  align-content: center;
  gap: 0.9rem;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="publications"] .ndppc-publications-banner-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="publications"] .ndppc-publications-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="publications"] .ndppc-publications-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.08;
}

body[data-page="publications"] .ndppc-publications-overview-band,
body[data-page="publications"] .ndppc-publications-record-band,
body[data-page="publications"] .ndppc-publications-doc-band,
body[data-page="publications"] .ndppc-publications-path-band {
  padding-top: 28px;
  padding-bottom: 28px;
}

body[data-page="publications"] .ndppc-publications-overview-band {
  background:
    linear-gradient(180deg, rgba(20, 53, 38, 0.04), rgba(20, 53, 38, 0)),
    linear-gradient(135deg, rgba(184, 146, 66, 0.08), rgba(255, 255, 255, 0.72));
}

body[data-page="publications"] .ndppc-publications-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(300px, 0.82fr);
  gap: 1.35rem;
  align-items: start;
}

body[data-page="publications"] .ndppc-publications-overview-copy {
  display: grid;
  gap: 1rem;
}

body[data-page="publications"] .ndppc-publications-overview-copy h2,
body[data-page="publications"] .ndppc-publications-record-band .ndppc-section-copy h3,
body[data-page="publications"] .ndppc-publications-doc-band .ndppc-section-copy h3,
body[data-page="publications"] .ndppc-publications-path-band .ndppc-section-copy h3 {
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
}

body[data-page="publications"] .ndppc-publications-overview-copy .ndppc-card-copy {
  margin: 0;
  text-align: justify;
  line-height: 1.85;
}

body[data-page="publications"] .ndppc-publications-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.95rem;
}

body[data-page="publications"] .ndppc-publications-stat-card {
  display: grid;
  gap: 0.35rem;
  align-content: center;
  min-height: 118px;
  padding: 1rem 1.05rem;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: rgba(255, 255, 255, 0.96);
}

body[data-page="publications"] .ndppc-publications-stat-card strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.1vw, 2.3rem);
  line-height: 1;
}

body[data-page="publications"] .ndppc-publications-stat-card span {
  color: rgba(20, 53, 38, 0.82);
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

body[data-page="publications"] .ndppc-publication-record-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.2rem;
}

body[data-page="publications"] .ndppc-publication-record-card {
  display: grid;
  grid-template-columns: minmax(170px, 0.44fr) minmax(0, 0.56fr);
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.98);
  overflow: hidden;
}

body[data-page="publications"] .ndppc-publication-record-media img {
  width: 100%;
  height: 100%;
  min-height: 220px;
  object-fit: cover;
  display: block;
}

body[data-page="publications"] .ndppc-publication-record-copy {
  display: grid;
  align-content: start;
  gap: 0.85rem;
  padding: 1.15rem 1.2rem;
}

body[data-page="publications"] .ndppc-publication-record-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.2rem;
}

body[data-page="publications"] .ndppc-publication-record-copy .ndppc-card-copy {
  margin: 0;
  line-height: 1.78;
}

body[data-page="publications"] .ndppc-publications-record-band .ndppc-section-bar,
body[data-page="publications"] .ndppc-publications-doc-band .ndppc-section-bar,
body[data-page="publications"] .ndppc-publications-path-band .ndppc-section-bar {
  margin-bottom: 1.15rem;
}

@media (max-width: 991px) {
  body[data-page="publications"] .ndppc-publications-banner-frame,
  body[data-page="publications"] .ndppc-publications-banner-frame img {
    min-height: 102px;
  }

  body[data-page="publications"] .ndppc-publications-overview-grid,
  body[data-page="publications"] .ndppc-publication-record-grid,
  body[data-page="publications"] .ndppc-publication-record-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="publications"] .ndppc-publications-banner-frame,
  body[data-page="publications"] .ndppc-publications-banner-frame img {
    min-height: 88px;
  }

  body[data-page="publications"] .ndppc-publications-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="publications"] .ndppc-publications-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="publications"] .ndppc-publications-overview-band,
  body[data-page="publications"] .ndppc-publications-record-band,
  body[data-page="publications"] .ndppc-publications-doc-band,
  body[data-page="publications"] .ndppc-publications-path-band {
    padding-top: 16px;
    padding-bottom: 16px;
  }

  body[data-page="publications"] .ndppc-publications-stat-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="publications"] .ndppc-publications-stat-card,
  body[data-page="publications"] .ndppc-publication-record-copy {
    padding: 1rem;
  }

  body[data-page="publications"] .ndppc-publication-record-media img {
    min-height: 210px;
  }
}

/* Final Sensor Workflows Redesign */
body[data-page="infrastructure"] .banner.ndppc-sensor-banner {
  padding-top: 0;
  margin-top: 0;
}

body[data-page="infrastructure"] .banner.ndppc-sensor-banner .container {
  max-width: none;
  padding-inline: 0;
}

body[data-page="infrastructure"] .banner.ndppc-sensor-banner .banner_inner {
  min-height: 0;
  padding: 0;
}

body[data-page="infrastructure"] .banner_content.ndppc-sensor-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
}

body[data-page="infrastructure"] .ndppc-sensor-banner-frame {
  position: relative;
  margin: 0;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  overflow: hidden;
}

body[data-page="infrastructure"] .ndppc-sensor-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  object-fit: cover;
  object-position: center center;
  display: block;
}

body[data-page="infrastructure"] .ndppc-sensor-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(247, 243, 233, 0.96) 0%, rgba(247, 243, 233, 0.9) 36%, rgba(247, 243, 233, 0.6) 58%, rgba(247, 243, 233, 0.18) 100%);
}

body[data-page="infrastructure"] .ndppc-sensor-banner-copy {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: min(1320px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 1rem 0 1rem;
  z-index: 1;
}

body[data-page="infrastructure"] .ndppc-sensor-banner-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.45rem;
  font-size: 0.92rem;
  font-weight: 600;
  color: rgba(18, 44, 34, 0.72);
}

body[data-page="infrastructure"] .ndppc-sensor-banner-breadcrumbs a {
  color: var(--ndppc-primary-dark);
}

body[data-page="infrastructure"] .ndppc-sensor-banner-copy h1 {
  max-width: none;
  margin: 0;
  font-size: clamp(1.5rem, 1.95vw, 2rem);
  line-height: 1.06;
  color: var(--ndppc-primary-dark);
}

@media (min-width: 992px) {
  body[data-page="infrastructure"] .ndppc-sensor-banner-copy h1 {
    white-space: nowrap;
  }
}

body[data-page="infrastructure"] .ndppc-sensor-overview-band,
body[data-page="infrastructure"] .ndppc-sensor-family-band,
body[data-page="infrastructure"] .ndppc-sensor-atlas-band,
body[data-page="infrastructure"] .ndppc-sensor-browser-band {
  padding: 40px 0;
}

body[data-page="infrastructure"] .ndppc-sensor-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 1.2rem;
  align-items: stretch;
}

body[data-page="infrastructure"] .ndppc-sensor-overview-copy,
body[data-page="infrastructure"] .ndppc-sensor-stat-card,
body[data-page="infrastructure"] .ndppc-sensor-family-card,
body[data-page="infrastructure"] .ndppc-sensor-atlas-card,
body[data-page="infrastructure"] .ndppc-sensor-browser-shell,
body[data-page="infrastructure"] .ndppc-sensor-browser-detail {
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 18px 34px rgba(20, 53, 38, 0.08);
}

body[data-page="infrastructure"] .ndppc-sensor-overview-copy {
  padding: 1.55rem 1.6rem;
  border-radius: 24px;
}

body[data-page="infrastructure"] .ndppc-sensor-overview-copy h2,
body[data-page="infrastructure"] .ndppc-sensor-section-head h2 {
  margin: 0 0 1rem;
  font-size: clamp(1.6rem, 2.15vw, 2.2rem);
  line-height: 1.14;
  color: var(--ndppc-primary-dark);
}

body[data-page="infrastructure"] .ndppc-sensor-overview-copy .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-section-head .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-family-card .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-atlas-card .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-stage-text .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-stat-card .ndppc-card-copy {
  color: var(--ndppc-copy);
  line-height: 1.78;
}

body[data-page="infrastructure"] .ndppc-sensor-keyline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin: 1.2rem 0 1.35rem;
}

body[data-page="infrastructure"] .ndppc-sensor-keyline span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.5rem 0.95rem;
  border-radius: 999px;
  background: var(--ndppc-accent-soft);
  color: #7a5a21;
  font-size: 0.9rem;
  font-weight: 700;
}

body[data-page="infrastructure"] .ndppc-sensor-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stat-card {
  padding: 1rem;
  border-radius: 20px;
}

body[data-page="infrastructure"] .ndppc-sensor-stat-card strong {
  display: block;
  margin-bottom: 0.28rem;
  font-size: 2rem;
  line-height: 1;
  color: var(--ndppc-primary-dark);
}

body[data-page="infrastructure"] .ndppc-sensor-stat-card h3 {
  margin: 0 0 0.45rem;
  font-size: 0.98rem;
  color: #7a5a21;
}

body[data-page="infrastructure"] .ndppc-sensor-section-head {
  margin-bottom: 1.2rem;
  max-width: 78ch;
}

body[data-page="infrastructure"] .ndppc-sensor-family-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card {
  padding: 1.2rem 1.2rem 1.1rem;
  border-radius: 22px;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card h3,
body[data-page="infrastructure"] .ndppc-sensor-atlas-card h3,
body[data-page="infrastructure"] .ndppc-sensor-stage-copy h3 {
  margin: 0.65rem 0 0.6rem;
  font-size: 1.2rem;
  line-height: 1.25;
  color: var(--ndppc-primary-dark);
}

body[data-page="infrastructure"] .ndppc-sensor-family-list {
  margin: 0.95rem 0 0;
  padding-left: 1.1rem;
  display: grid;
  gap: 0.42rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-list li {
  color: var(--ndppc-copy);
  line-height: 1.5;
}

body[data-page="infrastructure"] .ndppc-sensor-atlas-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-atlas-card {
  display: grid;
  gap: 0.85rem;
  padding: 1.1rem;
  border-radius: 22px;
  align-content: start;
}

body[data-page="infrastructure"] .ndppc-sensor-atlas-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

body[data-page="infrastructure"] .ndppc-sensor-atlas-code,
body[data-page="infrastructure"] .ndppc-sensor-stage-code {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 54px;
  min-height: 32px;
  padding: 0.25rem 0.6rem;
  border-radius: 999px;
  background: linear-gradient(180deg, #173d2e 0%, #214b39 100%);
  color: #fff;
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: 0.06em;
}

body[data-page="infrastructure"] .ndppc-sensor-atlas-media {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 96px;
  margin: 0;
  border-radius: 18px;
  background: #eef3ee;
  overflow: hidden;
}

body[data-page="infrastructure"] .ndppc-sensor-atlas-media img {
  width: min(100%, 92px);
  max-height: 92px;
  object-fit: contain;
  display: block;
}

body[data-page="infrastructure"] .ndppc-sensor-atlas-copy {
  display: grid;
  gap: 0.7rem;
}

body[data-page="infrastructure"] .ndppc-sensor-atlas-points,
body[data-page="infrastructure"] .ndppc-sensor-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell {
  display: grid;
  grid-template-columns: minmax(250px, 290px) minmax(0, 1fr);
  gap: 1rem;
  padding: 1rem;
  border-radius: 24px;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
  display: grid;
  gap: 0.8rem;
  align-content: start;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  display: grid;
  gap: 0.3rem;
  justify-items: start;
  padding: 1rem 1rem 0.95rem;
  border-radius: 18px;
  text-align: left;
  background: rgba(255, 255, 255, 0.9);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn strong {
  font-size: 0.98rem;
  line-height: 1.3;
  color: var(--ndppc-primary-dark);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn span {
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--ndppc-copy-soft);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active {
  background: linear-gradient(180deg, rgba(22, 61, 46, 0.98), rgba(30, 71, 55, 0.98));
  border-color: rgba(22, 61, 46, 0.98);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active strong,
body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active span {
  color: rgba(255, 255, 255, 0.95);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-detail {
  padding: 0;
  border-radius: 22px;
  overflow: hidden;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
  display: grid;
  grid-template-columns: minmax(220px, 0.78fr) minmax(0, 1.22fr);
  min-height: 100%;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-media {
  background: #eef3ee;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
  width: min(100%, 180px);
  max-height: 180px;
  object-fit: contain;
  display: block;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-copy {
  padding: 1.35rem 1.4rem 1.3rem;
  background: rgba(255, 255, 255, 0.98);
}

body[data-page="infrastructure"] .ndppc-sensor-stage-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.8rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-text {
  display: grid;
  gap: 0.7rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-points-wrap {
  margin-top: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-points-wrap strong {
  display: block;
  margin-bottom: 0.65rem;
  color: var(--ndppc-primary-dark);
  font-size: 0.92rem;
}

@media (max-width: 1199px) {
  body[data-page="infrastructure"] .ndppc-sensor-overview-grid,
  body[data-page="infrastructure"] .ndppc-sensor-family-grid,
  body[data-page="infrastructure"] .ndppc-sensor-atlas-grid,
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell,
  body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body[data-page="infrastructure"] .ndppc-sensor-banner-frame,
  body[data-page="infrastructure"] .ndppc-sensor-banner-frame img {
    min-height: 102px;
  }
}

@media (max-width: 767px) {
  body[data-page="infrastructure"] .ndppc-sensor-banner-frame,
  body[data-page="infrastructure"] .ndppc-sensor-banner-frame img {
    min-height: 88px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-banner-copy {
    padding: 0.75rem 0;
  }

  body[data-page="infrastructure"] .ndppc-sensor-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-overview-band,
  body[data-page="infrastructure"] .ndppc-sensor-family-band,
  body[data-page="infrastructure"] .ndppc-sensor-atlas-band,
  body[data-page="infrastructure"] .ndppc-sensor-browser-band {
    padding: 32px 0;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stat-grid,
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-overview-copy,
  body[data-page="infrastructure"] .ndppc-sensor-stat-card,
  body[data-page="infrastructure"] .ndppc-sensor-family-card,
  body[data-page="infrastructure"] .ndppc-sensor-atlas-card,
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell,
  body[data-page="infrastructure"] .ndppc-sensor-browser-detail,
  body[data-page="infrastructure"] .ndppc-sensor-stage-copy {
    padding: 1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-overview-copy h2,
  body[data-page="infrastructure"] .ndppc-sensor-section-head h2 {
    font-size: 1.58rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-atlas-media {
    min-height: 84px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-atlas-media img,
  body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
    max-height: 120px;
  }
}

/* Template Reframe Override */
:root {
  --color-blue5: #143526;
  --color-yellow: #b89242;
  --ndppc-primary: #143526;
  --ndppc-primary-dark: #0d2418;
  --ndppc-accent: #b89242;
  --ndppc-accent-soft: #f4ecda;
  --ndppc-surface: #f5f1e8;
  --ndppc-surface-alt: #ece5d7;
  --ndppc-card: #ffffff;
  --ndppc-line: rgba(20, 53, 38, 0.12);
  --ndppc-copy: #1e2f26;
  --ndppc-copy-soft: #5f6d64;
  --ndppc-shadow: 0 18px 36px rgba(20, 53, 38, 0.08);
  --ndppc-radius: 18px;
  --ndppc-radius-sm: 12px;
  --ndppc-header-offset: 198px;
}

html,
body {
  display: block !important;
  min-height: auto !important;
}

body {
  font-family: "Noto Sans", "Segoe UI", sans-serif;
  color: var(--ndppc-copy);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.14), transparent 24%),
    linear-gradient(180deg, #faf7f0 0%, #f2ece0 100%);
  padding-top: var(--ndppc-header-offset) !important;
  overflow-x: hidden;
}

h1,
h2,
h3,
h4,
h5,
h6,
.banner_logo h1,
.ndppc-brand-note strong,
.heading-style-1 {
  font-family: "Lexend Deca", "Noto Sans", sans-serif !important;
}

main {
  min-height: calc(100vh - var(--ndppc-header-offset));
}

.ndppc-site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1400;
}

.ndppc-site-header .header-top {
  background: #0f2b1e;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.ndppc-site-header .header-top .row {
  min-height: 42px;
  align-items: center;
}

.ndppc-top-link,
.ndppc-site-header .header-top a,
.ndppc-site-header .header-top strong,
.ndppc-site-header .header-top span,
.ndppc-site-header .header-top button,
.ndppc-site-header .header-top select,
.ndppc-site-header .header-top label {
  color: #fff !important;
}

.ndppc-site-header .header-area {
  background: rgba(249, 246, 239, 0.96);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 10px 24px rgba(20, 53, 38, 0.08);
}

.ndppc-brand-band {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1rem 0 0.85rem;
}

.ndppc-brand-image {
  display: block;
  flex: 0 1 700px;
}

.ndppc-brand-image img {
  width: 100%;
  max-width: 700px;
  height: auto;
  display: block;
}

.ndppc-brand-note {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.32rem;
  text-align: right;
  flex: 0 1 420px;
}

.ndppc-brand-note strong {
  font-size: 0.98rem;
  line-height: 1.45;
  color: var(--ndppc-primary);
}

.ndppc-brand-note span {
  font-size: 0.84rem;
  color: var(--ndppc-copy-soft);
}

.ndppc-navbar {
  padding: 0.1rem 0 0.9rem;
}

.ndppc-site-header .container-fluid {
  padding-left: 10;
  padding-right: 20;
}

.ndppc-site-header .navbar-nav {
  gap: 0.28rem;
}

.ndppc-site-header .nav-link,
.ndppc-site-header .dropdown-item {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ndppc-primary) !important;
  border-radius: 999px;
}

.ndppc-site-header .nav-link {
  padding: 0.65rem 1rem !important;
}

.ndppc-site-header .nav-link.active,
.ndppc-site-header .nav-link:hover,
.ndppc-site-header .dropdown-item.active,
.ndppc-site-header .dropdown-item:hover {
  color: #fff !important;
  background: linear-gradient(135deg, var(--ndppc-primary) 0%, #1d4d38 100%);
}

.ndppc-site-header .dropdown-menu {
  border: 1px solid rgba(20, 53, 38, 0.08);
  border-radius: 16px;
  padding: 0.6rem;
  box-shadow: var(--ndppc-shadow);
}

.ndppc-header-tools {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-left: 1rem;
}

.ndppc-header-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.72rem 1rem;
  border-radius: 999px;
  background: rgba(20, 53, 38, 0.06);
  color: var(--ndppc-primary) !important;
  font-weight: 700;
}

.ndppc-header-link:hover {
  background: rgba(20, 53, 38, 0.1);
}

.login-btn,
.ndppc-link-btn,
.ndppc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 46px;
  padding: 0.82rem 1.25rem;
  border-radius: 999px !important;
  border: 1px solid var(--ndppc-primary);
  background: linear-gradient(135deg, var(--ndppc-primary) 0%, #1d4d38 100%);
  color: #fff !important;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(20, 53, 38, 0.16);
}

.ndppc-outline-btn,
.ndppc-btn-outline {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.45rem;
  min-height: 46px;
  padding: 0.82rem 1.25rem;
  border-radius: 999px !important;
  border: 1px solid rgba(20, 53, 38, 0.18);
  background: rgba(255, 255, 255, 0.9);
  color: var(--ndppc-primary) !important;
  font-weight: 700;
}

.ndppc-link-btn:hover,
.ndppc-btn:hover,
.ndppc-outline-btn:hover,
.ndppc-btn-outline:hover,
.login-btn:hover {
  transform: translateY(-1px);
}

.ndppc-inline-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: var(--ndppc-primary) !important;
  font-weight: 700;
}

.ndppc-inline-link:hover {
  color: var(--ndppc-primary-dark) !important;
}

.ndppc-inline-link-icon {
  justify-content: center;
  width: 34px;
  min-width: 34px;
  height: 34px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(16, 40, 31, 0.14);
  background: rgba(16, 40, 31, 0.06);
  color: var(--ndppc-primary) !important;
}

.ndppc-inline-link-icon .material-symbols-outlined,
.ndppc-inline-link-glyph {
  font-size: 0.92rem;
  line-height: 1;
}

.ndppc-inline-link-glyph {
  font-weight: 800;
  letter-spacing: -0.02em;
}

.ndppc-inline-link-institutional {
  background: rgba(28, 92, 67, 0.1);
  border-color: rgba(28, 92, 67, 0.18);
}

.ndppc-inline-link-linkedin {
  background: rgba(10, 102, 194, 0.1);
  border-color: rgba(10, 102, 194, 0.18);
  color: #0a66c2 !important;
}

.ndppc-inline-link-x {
  background: rgba(17, 24, 39, 0.08);
  border-color: rgba(17, 24, 39, 0.18);
  color: #111827 !important;
}

.ndppc-inline-link-mail {
  background: rgba(181, 152, 89, 0.1);
  border-color: rgba(181, 152, 89, 0.22);
  color: #8a6521 !important;
}

.ndppc-inline-link-icon:hover {
  transform: translateY(-1px);
}

.ndppc-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.ndppc-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
}

.banner,
.explore,
.services,
.news,
.application,
.find-map,
.ndppc-shell,
.ndppc-page-hero {
  position: relative;
  padding: 72px 0;
}

.banner_inner,
.explore_inner,
.need-support-content,
.find-map-content,
.waw-inner,
.footer_inner {
  position: relative;
  z-index: 1;
}

.banner.ndppc-home-banner,
.banner.ndppc-page-banner {
  padding-top: 52px;
  padding-bottom: 72px;
}

.banner.ndppc-home-banner .banner_inner,
.banner.ndppc-page-banner .banner_inner {
  padding: 1rem;
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(20, 53, 38, 0.95) 0%, rgba(30, 78, 55, 0.92) 56%, rgba(184, 146, 66, 0.84) 100%);
  box-shadow: 0 28px 52px rgba(20, 53, 38, 0.16);
}

.banner_content.ndppc-home-banner-grid,
.banner_content.ndppc-page-banner-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(340px, 0.9fr);
  gap: 1.5rem;
  align-items: stretch;
}

.ndppc-banner-copy,
.ndppc-banner-panel,
.ndppc-page-banner-panel {
  border-radius: 24px;
}

.ndppc-banner-copy {
  padding: 2.1rem;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.ndppc-banner-copy .rounded-pill,
.ndppc-page-banner .rounded-pill {
  background: rgba(255, 248, 231, 0.2);
  color: #fff5dc;
}

.ndppc-banner-emblem {
  width: 76px;
  height: 76px;
  object-fit: contain;
  margin-bottom: 1rem;
}

.banner_logo h1 {
  font-size: clamp(2.1rem, 4vw, 3.5rem);
  line-height: 1.08;
  color: #fff;
  margin: 1rem 0 1rem;
}

.banner_logo p,
.banner_find p,
.ndppc-page-banner .banner_logo p {
  color: rgba(255, 255, 255, 0.88);
  font-size: 1rem;
}

.banner-chip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-top: 1.2rem;
}

.banner-chip a.rounded-pill {
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
}

.banner_find {
  margin-top: 1.3rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.banner_find a {
  color: #fff6da !important;
  font-weight: 700;
}

.ndppc-banner-panel,
.ndppc-page-banner-panel {
  background: rgba(255, 255, 255, 0.96);
  padding: 1.1rem;
  border: 1px solid rgba(255, 255, 255, 0.18);
}

.ndppc-page-banner-panel {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100%;
}

.ndppc-page-banner-panel img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  border-radius: 18px;
}

.ndppc-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.95rem;
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.92rem;
}

.ndppc-breadcrumbs a {
  color: #fff;
}

.ndppc-hero-slide {
  overflow: hidden;
  border-radius: 18px;
  background: #fff;
}

.ndppc-hero-slide img {
  width: 100%;
  height: 280px;
  object-fit: cover;
}

.ndppc-hero-slide figcaption {
  padding: 1.2rem 1.2rem 1.35rem;
}

.ndppc-hero-slide figcaption h3 {
  font-size: 1.2rem;
  margin: 0.9rem 0 0.55rem;
  color: var(--ndppc-primary);
}

.ndppc-hero-slide figcaption p {
  color: var(--ndppc-copy-soft);
}

.ndppc-hero-stat-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.8rem;
  margin-top: 1rem;
}

.ndppc-hero-stat {
  padding: 1rem 1.05rem;
  border-radius: 18px;
  background: rgba(20, 53, 38, 0.06);
  border: 1px solid rgba(20, 53, 38, 0.08);
}

.ndppc-hero-stat strong {
  display: block;
  color: var(--ndppc-primary);
  font-size: 1rem;
}

.ndppc-hero-stat span {
  display: block;
  margin-top: 0.35rem;
  color: var(--ndppc-copy-soft);
  font-size: 0.84rem;
}

.ndppc-alert-strip-template {
  padding: 0;
  background: #f0eadb;
  border-bottom: 1px solid rgba(20, 53, 38, 0.08);
}

.ndppc-alert-strip-inner {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 1rem;
  align-items: center;
  padding: 0.82rem 0;
}

.ndppc-alert-marquee {
  position: relative;
  overflow: hidden;
}

.ndppc-alert-marquee-track {
  display: inline-flex;
  gap: 2.5rem;
  min-width: max-content;
  animation: ndppc-marquee 30s linear infinite;
}

.ndppc-alert-marquee-track a {
  color: var(--ndppc-primary);
  font-weight: 700;
  white-space: nowrap;
}

@keyframes ndppc-marquee {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

.ndppc-home-explore .explore_inner,
.explore .explore_inner {
  padding: 2rem;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96) 0%, rgba(247, 241, 229, 0.98) 100%);
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: var(--ndppc-shadow);
}

.ndppc-section-bar,
.ndppc-section-heading {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 2rem;
}

.explore_head h3 {
  font-size: clamp(1.7rem, 2.5vw, 2.4rem);
  margin: 0.85rem 0 0.65rem;
  color: var(--ndppc-primary);
}

.explore_head p {
  max-width: 780px;
  font-size: 1rem;
  color: var(--ndppc-copy-soft);
}

.services_chip {
  gap: 1rem;
}

.services_chip .ndppc-category-entry {
  display: grid !important;
  grid-template-columns: auto 1fr auto;
  gap: 0.85rem;
  align-items: center;
  width: min(100%, 320px);
  padding: 1rem 1.15rem;
  border-radius: 18px;
  background: #fff;
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 14px 28px rgba(20, 53, 38, 0.06);
}

.services_chip .ndppc-category-entry i {
  width: 46px;
  height: 46px;
  color: #fff;
}

.ndppc-icon-amber,
.icon_1 {
  background: linear-gradient(135deg, #b89242 0%, #d3b06a 100%);
}

.ndppc-icon-green,
.icon_2 {
  background: linear-gradient(135deg, #1d5a42 0%, #2d7a58 100%);
}

.ndppc-icon-blue,
.icon_3 {
  background: linear-gradient(135deg, #25627a 0%, #2d839c 100%);
}

.ndppc-icon-warm,
.icon_4 {
  background: linear-gradient(135deg, #8c5431 0%, #b36f3f 100%);
}

.ndppc-icon-violet,
.icon_5 {
  background: linear-gradient(135deg, #5b5c8d 0%, #7a7cb0 100%);
}

.ndppc-icon-sage,
.icon_6 {
  background: linear-gradient(135deg, #60734f 0%, #7f956a 100%);
}

.ndppc-icon-gold,
.icon_7 {
  background: linear-gradient(135deg, #8f6a23 0%, #bd9131 100%);
}

.ndppc-icon-stone,
.icon_8 {
  background: linear-gradient(135deg, #49545c 0%, #68757e 100%);
}

.services_chip .ndppc-category-entry strong {
  color: var(--ndppc-primary);
  font-size: 0.96rem;
}

.services_chip .ndppc-category-entry .material-symbols-outlined:last-child {
  color: var(--ndppc-accent);
}

.ndppc-home-overview .waw-inner,
.waw .waw-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(340px, 0.92fr);
  gap: 1.5rem;
  align-items: stretch;
}

.waw-left,
.waw-right {
  min-width: 0;
}

.waw-left,
.waw-right,
.ndppc-copy-card,
.ndppc-doc-card,
.ndppc-link-card,
.ndppc-capability-card,
.ndppc-tab-card,
.ndppc-directory-card,
.ndppc-stat-card,
.counter-box,
.application-card,
.news-card,
.ndppc-banner-panel,
.ndppc-page-banner-panel,
.ndppc-map-frame,
.ndppc-iframe-shell {
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: var(--ndppc-shadow);
}

.waw-left,
.waw-right {
  padding: 1.7rem;
  border-radius: 24px;
}

.ndppc-copy-stack p + p {
  margin-top: 1rem;
}

.ndppc-pill-row,
.ndppc-keyword-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

.ndppc-pill,
.ndppc-keyword-grid .rounded-pill {
  background: #f5ecd7;
  color: #76591f;
}

.ndppc-importance-card {
  overflow: hidden;
  border-radius: 18px;
}

.ndppc-importance-card img {
  width: 100%;
  height: 300px;
  object-fit: cover;
}

.ndppc-importance-copy {
  padding: 1.2rem 1.2rem 1.35rem;
}

.counter.ndppc-home-counter,
.ndppc-stat-grid {
  position: static;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.5rem;
}

.counter-box,
.ndppc-stat-card {
  padding: 1.35rem;
  border-radius: 20px;
}

.ndppc-count {
  font-family: "Lexend Deca", "Noto Sans", sans-serif;
  font-size: 2rem;
  line-height: 1;
  color: var(--ndppc-primary);
}

.counter-box strong,
.ndppc-stat-card strong {
  display: block;
  font-size: 1rem;
  color: var(--ndppc-primary);
}

.counter-box p,
.ndppc-stat-card p {
  color: var(--ndppc-copy-soft);
}

.services_card {
  margin-top: 1.4rem;
}

.services_card .icon {
  top: -22px;
  left: 24px;
  width: 54px;
  height: 54px;
  color: #fff;
  z-index: 2;
}

.services_card_inner {
  min-height: 280px;
  padding: 2rem 1.4rem 1.4rem;
  border-radius: 22px;
  background: #fff;
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: var(--ndppc-shadow);
}

.services_card_inner .effect {
  width: 180px;
  height: 180px;
  top: -40px;
  right: -38px;
  opacity: 0.12;
  background: linear-gradient(135deg, var(--ndppc-accent) 0%, var(--ndppc-primary) 100%);
}

.services_card_content {
  gap: 0.65rem;
}

.services_card_content span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0.16rem 0.72rem;
  border-radius: 999px;
  background: rgba(20, 53, 38, 0.08);
  color: var(--ndppc-primary);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.services_card_content h3 {
  color: var(--ndppc-primary);
  font-size: 1.18rem;
}

.services_card_content h5,
.services_card_content p {
  color: var(--ndppc-copy-soft);
  font-size: 0.95rem;
  line-height: 1.7;
}

.services_card .hover-visible {
  display: none !important;
}

.services_card:hover .hover-visible {
  display: flex !important;
}

.services_card:hover .none-visible {
  display: none !important;
}

.ndppc-card-btn {
  margin-top: 0.35rem;
  padding: 0.72rem 1rem !important;
  border-radius: 999px !important;
  border: 1px solid var(--ndppc-primary);
  background: rgba(20, 53, 38, 0.08);
  color: var(--ndppc-primary) !important;
  font-weight: 700;
}

.ndppc-research-grid,
.ndppc-home-split,
.ndppc-support-grid,
.ndppc-copy-grid,
.ndppc-split-grid,
.ndppc-contact-layout,
.find-map-content.ndppc-map-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 1.5rem;
}

.ndppc-notice-stack {
  display: grid;
  gap: 1rem;
}

.ndppc-project-card,
.ndppc-notice-panel,
.ndppc-person-card,
.ndppc-doc-card,
.ndppc-link-card,
.ndppc-facility-card,
.news-card,
.application-card {
  border-radius: 22px;
  overflow: hidden;
}

.ndppc-project-card-media img,
.ndppc-facility-media img,
.ndppc-person-card-media img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.ndppc-project-card-copy,
.application-content-inner,
.news-card,
.ndppc-notice-panel {
  padding: 1.35rem;
}

.application-content-inner h3,
.news-card h3,
.ndppc-project-card h3 {
  color: var(--ndppc-primary);
}

.ndppc-doc-grid,
.ndppc-link-grid,
.ndppc-card-grid,
.ndppc-directory-grid,
.ndppc-gallery-grid,
.ndppc-grid-2,
.ndppc-grid-3,
.ndppc-contact-grid,
.ndppc-media-grid,
.ndppc-team-grid,
.ndppc-network-columns,
.ndppc-footer-inner {
  display: grid;
  gap: 1rem;
}

.ndppc-grid-2,
.ndppc-contact-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ndppc-grid-3,
.ndppc-card-grid,
.ndppc-directory-grid,
.ndppc-gallery-grid,
.ndppc-media-grid,
.ndppc-footer-inner {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ndppc-doc-grid,
.ndppc-link-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ndppc-team-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ndppc-network-columns {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.ndppc-inline-image {
  width: 100%;
  border-radius: 14px;
}

.ndppc-mini-heading,
.ndppc-mini-title {
  margin: 0 0 1rem;
  color: var(--ndppc-primary);
  font-size: 1rem;
}

.find-map.ndppc-home-access,
.find-map {
  background:
    linear-gradient(135deg, rgba(20, 53, 38, 0.95) 0%, rgba(26, 69, 49, 0.93) 58%, rgba(184, 146, 66, 0.88) 100%);
}

.ndppc-map-layout,
.ndppc-contact-layout {
  align-items: stretch;
}

.ndppc-map-copy {
  color: #fff;
  padding: 2rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.08);
}

.ndppc-map-copy h3 {
  color: #fff;
  margin: 1rem 0 0.8rem;
}

.ndppc-map-copy p,
.ndppc-map-copy a {
  color: rgba(255, 255, 255, 0.88);
}

.ndppc-map-copy .rounded-pill {
  background: rgba(255, 255, 255, 0.16);
  color: #fff5da;
}

.ndppc-map-frame,
.ndppc-iframe-shell {
  padding: 0.8rem;
  border-radius: 24px;
}

.ndppc-map-frame iframe,
.ndppc-iframe-shell iframe {
  display: block;
  width: 100%;
  min-height: 360px;
  border: 0;
  border-radius: 18px;
}

.ndppc-iframe-shell h3 {
  margin: 0 0 1rem;
  color: var(--ndppc-primary);
  padding: 0.5rem 0.5rem 0;
}

.footer_need_support,
.ndppc-footer,
.ndppc-subfooter {
  position: relative;
}

.ndppc-footer-cta {
  padding: 0;
}

.ndppc-footer-cta-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 2rem;
  border-radius: 26px;
  background: linear-gradient(135deg, var(--ndppc-primary) 0%, #2c6249 100%);
  transform: translateY(36px);
}

.ndppc-footer {
  background: #0f2b1e;
  padding: 84px 0 34px;
}

.ndppc-footer-inner {
  grid-template-columns: 1.3fr 1fr 1fr 1fr;
}

.ndppc-footer h3,
.ndppc-footer strong,
.ndppc-footer p,
.ndppc-footer a,
.ndppc-subfooter,
.ndppc-subfooter a {
  color: #fff !important;
}

.ndppc-footer-brand {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.ndppc-footer-brand img {
  width: 64px;
  height: 64px;
  object-fit: contain;
}

.ndppc-cluster {
  min-height: 200px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.btn-last-update {
  margin-top: 1rem;
  padding: 0.78rem 1rem;
  border-radius: 999px !important;
  background: rgba(255, 255, 255, 0.08);
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.14);
}

.ndppc-subfooter {
  background: #0a1c14;
  padding: 1rem 0;
}

.ndppc-subfooter-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.ndppc-subfooter ul {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin: 0;
  padding: 0;
}

.ndppc-access-panel {
  position: fixed !important;
  right: 1rem !important;
  top: auto !important;
  bottom: 1rem !important;
  width: min(420px, calc(100vw - 2rem));
  padding: 1rem;
  border-radius: 22px;
  background: #fff;
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 24px 40px rgba(20, 53, 38, 0.18);
  z-index: 1500;
}

.ndppc-accessibility-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.ndppc-control-btn {
  min-height: 44px;
  border-radius: 14px;
  border: 1px solid rgba(20, 53, 38, 0.12);
  background: #fff;
  color: var(--ndppc-primary);
  font-weight: 700;
}

.ndppc-close-btn {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  border: 1px solid rgba(20, 53, 38, 0.12);
  background: #fff;
}

.ndppc-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
}

.ndppc-filter-btn {
  min-height: 42px;
  padding: 0.68rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(20, 53, 38, 0.14);
  background: rgba(255, 255, 255, 0.9);
  color: var(--ndppc-primary);
  font-weight: 700;
}

.ndppc-filter-btn.is-active {
  background: var(--ndppc-primary);
  color: #fff;
  border-color: var(--ndppc-primary);
}

.is-hidden {
  display: none !important;
}

.ndppc-media-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ndppc-media-card {
  overflow: hidden;
  border-radius: 20px;
  background: #fff;
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: var(--ndppc-shadow);
}

.ndppc-media-trigger {
  width: 100%;
  background: none;
  padding: 0;
  text-align: left;
}

.ndppc-media-trigger img,
.ndppc-media-trigger video {
  width: 100%;
  height: 240px;
  object-fit: cover;
}

.ndppc-media-tag {
  position: absolute;
  top: 1rem;
  left: 1rem;
  padding: 0.3rem 0.7rem;
  border-radius: 999px;
  background: rgba(20, 53, 38, 0.85);
  color: #fff;
  font-size: 0.74rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.ndppc-media-trigger {
  position: relative;
  display: block;
}

.ndppc-media-copy {
  padding: 1rem 1.1rem 1.2rem;
}

.ndppc-lightbox {
  position: fixed;
  inset: 0;
  background: rgba(7, 17, 12, 0.82);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
  z-index: 1600;
}

.ndppc-lightbox-body {
  max-width: min(960px, 100%);
  width: 100%;
  background: #fff;
  border-radius: 24px;
  padding: 1rem;
}

.ndppc-lightbox-body img,
.ndppc-lightbox-body video {
  width: 100%;
  max-height: 70vh;
  object-fit: contain;
  border-radius: 18px;
}

.ndppc-lightbox-body p {
  margin: 1rem 0 0;
}

.ndppc-lightbox-close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #fff;
  color: var(--ndppc-primary);
  font-size: 1.7rem;
  line-height: 1;
}

body.ndppc-lightbox-open {
  overflow: hidden;
}

.ndppc-contrast {
  background: #101614 !important;
  color: #f7f4ea !important;
}

.ndppc-contrast .application-card,
.ndppc-contrast .news-card,
.ndppc-contrast .counter-box,
.ndppc-contrast .waw-left,
.ndppc-contrast .waw-right,
.ndppc-contrast .ndppc-banner-panel,
.ndppc-contrast .ndppc-page-banner-panel,
.ndppc-contrast .explore_inner {
  background: #17201c !important;
  color: #f7f4ea !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
}

.owl-theme .owl-nav {
  display: flex;
  justify-content: flex-end;
  gap: 0.6rem;
  margin-top: 1rem;
}

.owl-theme .owl-nav button.owl-prev,
.owl-theme .owl-nav button.owl-next {
  width: 42px;
  height: 42px;
  border-radius: 50% !important;
  background: rgba(20, 53, 38, 0.08) !important;
  color: var(--ndppc-primary) !important;
}

.owl-theme .owl-dots .owl-dot span {
  background: rgba(20, 53, 38, 0.22) !important;
}

.owl-theme .owl-dots .owl-dot.active span {
  background: var(--ndppc-primary) !important;
}

@media (max-width: 1199px) {
  :root {
    --ndppc-header-offset: 186px;
  }

  .banner_content.ndppc-home-banner-grid,
  .banner_content.ndppc-page-banner-grid,
  .ndppc-home-overview .waw-inner,
  .waw .waw-inner,
  .ndppc-research-grid,
  .ndppc-home-split,
  .ndppc-contact-layout,
  .find-map-content.ndppc-map-layout {
    grid-template-columns: 1fr;
  }

  .counter.ndppc-home-counter,
  .ndppc-stat-grid,
  .ndppc-grid-3,
  .ndppc-card-grid,
  .ndppc-directory-grid,
  .ndppc-gallery-grid,
  .ndppc-media-grid,
  .ndppc-team-grid,
  .ndppc-footer-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ndppc-footer-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  :root {
    --ndppc-header-offset: 164px;
  }

  .ndppc-brand-band {
    flex-direction: column;
    align-items: flex-start;
  }

  .ndppc-brand-note {
    align-items: flex-start;
    text-align: left;
  }

  .ndppc-site-header .navbar-toggler {
    border: 1px solid rgba(20, 53, 38, 0.14);
    background: #fff;
    border-radius: 14px;
  }

  .ndppc-site-header .navbar-toggler-icon {
    filter: none;
  }

  .ndppc-site-header .navbar-collapse {
    margin-top: 1rem;
    padding: 1rem;
    border-radius: 20px;
    background: #fff;
    border: 1px solid rgba(20, 53, 38, 0.08);
    box-shadow: var(--ndppc-shadow);
  }

  .ndppc-header-tools {
    margin-left: 0;
    margin-top: 1rem;
    flex-wrap: wrap;
  }

  .ndppc-network-columns,
  .ndppc-doc-grid,
  .ndppc-link-grid,
  .ndppc-grid-2,
  .ndppc-contact-grid {
    grid-template-columns: 1fr;
  }

  .ndppc-hero-stat-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  :root {
    --ndppc-header-offset: 148px;
  }

  .banner,
  .explore,
  .services,
  .news,
  .application,
  .find-map,
  .ndppc-shell,
  .ndppc-page-hero {
    padding: 56px 0;
  }

  .banner.ndppc-home-banner,
  .banner.ndppc-page-banner {
    padding-top: 32px;
    padding-bottom: 56px;
  }

  .ndppc-banner-copy,
  .waw-left,
  .waw-right,
  .ndppc-map-copy,
  .ndppc-footer-cta-inner,
  .explore .explore_inner {
    padding: 1.25rem;
  }

  .counter.ndppc-home-counter,
  .ndppc-stat-grid,
  .ndppc-grid-3,
  .ndppc-card-grid,
  .ndppc-directory-grid,
  .ndppc-gallery-grid,
  .ndppc-media-grid,
  .ndppc-team-grid,
  .ndppc-footer-inner {
    grid-template-columns: 1fr;
  }

  .ndppc-alert-strip-inner,
  .ndppc-section-bar,
  .ndppc-section-heading,
  .ndppc-subfooter-inner,
  .ndppc-footer-cta-inner {
    grid-template-columns: 1fr;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
  }

  .ndppc-brand-image img {
    max-width: 100%;
  }

  .banner_logo h1 {
    font-size: 2rem;
  }

  .ndppc-hero-slide img,
  .ndppc-importance-card img,
  .ndppc-project-card-media img,
  .ndppc-facility-media img,
  .ndppc-person-card-media img,
  .ndppc-media-trigger img,
  .ndppc-media-trigger video {
    height: 220px;
  }
}

@media (max-width: 575px) {
  :root {
    --ndppc-header-offset: 136px;
  }

  .ndppc-site-header .header-top .row {
    min-height: auto;
    padding: 0.35rem 0;
  }

  .banner_inner,
  .explore_inner,
  .ndppc-footer-cta-inner {
    border-radius: 22px;
  }

  .services_chip .ndppc-category-entry {
    width: 100%;
  }

  .ndppc-accessibility-grid {
    grid-template-columns: 1fr;
  }

  .ndppc-alert-marquee-track {
    gap: 1.4rem;
  }
}

/* Masthead Simplification Override */
.ndppc-brand-band,
.ndppc-brand-note {
  display: none !important;
}

.ndppc-navbar {
  padding: 0.9rem 0 !important;
}

.ndppc-site-header .navbar {
  padding: 0 !important;
}

.ndppc-navbar-brand {
  display: inline-flex;
  align-items: center;
  flex: 0 1 540px;
  min-width: 0;
  margin-right: 1.5rem;
}

.ndppc-navbar-brand img {
  width: 100%;
  max-width: 540px;
  height: auto;
  display: block;
}

.ndppc-site-header .navbar-collapse {
  justify-content: flex-end;
}

@media (max-width: 991px) {
  .ndppc-navbar-brand {
    flex: 1 1 auto;
    max-width: calc(100% - 70px);
    margin-right: 0.9rem;
  }

  .ndppc-navbar-brand img {
    max-width: 100%;
  }
}

@media (max-width: 575px) {
  .ndppc-navbar-brand {
    max-width: calc(100% - 62px);
  }
}

/* Static Shell And Overlap Corrections */
.ndppc-site-header .header-top {
  padding: 0;
}

.ndppc-topbar-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 42px;
  white-space: nowrap;
  flex-wrap: nowrap;
}

.ndppc-topbar-left,
.ndppc-topbar-right {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  min-width: 0;
}

.ndppc-topbar-left {
  flex: 1 1 auto;
  overflow: hidden;
}

.ndppc-topbar-right {
  flex: 0 0 auto;
}

.ndppc-topbar-left .goi,
.ndppc-topbar-left .goi a,
.ndppc-topbar-skip,
.ndppc-topbar-reader strong {
  white-space: nowrap;
}

.ndppc-topbar-skip {
  color: #fff !important;
  font-weight: 600;
}

.ndppc-topbar-divider {
  opacity: 0.5;
}

.ndppc-font-tools {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.ndppc-font-tools .font01 {
  min-width: 28px;
}

.ndppc-topbar-reader {
  gap: 0.35rem;
}

.ndppc-site-header .container-fluid {
  display: flex;
  align-items: center;
  gap: 1rem;
}

.ndppc-site-header .navbar-collapse {
  justify-content: flex-end;
  min-width: 0;
}

.ndppc-site-header .navbar-nav {
  flex-wrap: wrap;
  justify-content: flex-end;
}

.ndppc-header-tools {
  flex-shrink: 0;
}

.footer_need_support.ndppc-footer-cta {
  margin-top: 0;
}

.ndppc-footer-cta-inner {
  transform: none !important;
}

.ndppc-footer {
  padding-top: 48px;
}

.owl-carousel .owl-stage {
  display: flex;
  align-items: stretch;
}

.owl-carousel .owl-item {
  float: none;
  display: flex;
  height: auto;
}

.owl-carousel .item {
  width: 100%;
  height: 100%;
}

.application-card,
.news-card,
.counter-box,
.services_card,
.services_card_inner,
.ndppc-project-card,
.ndppc-doc-card,
.ndppc-link-card,
.ndppc-facility-card,
.ndppc-person-card {
  height: 100%;
}

.ndppc-home-services,
.ndppc-home-research,
.ndppc-home-people,
.ndppc-home-network,
.ndppc-home-access,
.application,
.news,
.services,
.explore,
.waw,
.find-map {
  clear: both;
}

@media (max-width: 1199px) {
  .ndppc-topbar-right {
    gap: 0.6rem;
  }

  .ndppc-topbar-reader strong {
    display: none;
  }
}

@media (max-width: 991px) {
  .ndppc-topbar-line {
    min-height: 38px;
  }

  .ndppc-topbar-right {
    display: none;
  }

  .ndppc-topbar-left {
    width: 100%;
    justify-content: space-between;
    gap: 0.65rem;
  }

  .ndppc-topbar-left .goi strong {
    font-size: 0.82rem;
  }

  .ndppc-site-header .container-fluid {
    gap: 0.65rem;
  }

  .ndppc-site-header .navbar-nav {
    flex-wrap: nowrap;
  }
}

@media (max-width: 767px) {
  .ndppc-topbar-left {
    justify-content: flex-start;
  }

  .ndppc-topbar-skip,
  .ndppc-topbar-divider {
    display: none;
  }

  .ndppc-topbar-left .goi strong {
    max-width: calc(100vw - 80px);
    overflow: hidden;
    text-overflow: ellipsis;
    display: inline-block;
    vertical-align: middle;
  }
}

/* Header Width And Single-Line Nav Override */
.ndppc-site-header .container {
  max-width: 1460px;
}

.ndppc-navbar {
  padding-left: 0.35rem !important;
  padding-right: 0.35rem !important;
}

.ndppc-navbar-brand {
  flex: 0 1 460px;
  margin-right: 2rem;
}

.ndppc-navbar-brand img {
  max-width: 460px;
}

.ndppc-site-header .container-fluid {
  gap: 1.35rem;
}

.ndppc-site-header .navbar-collapse {
  flex: 1 1 auto;
}

.ndppc-site-header .navbar-nav {
  flex-wrap: nowrap !important;
  gap: 0.14rem;
}

.ndppc-site-header .nav-link {
  padding: 0.6rem 0.78rem !important;
  font-size: 0.9rem;
  white-space: nowrap;
}

.ndppc-header-tools {
  margin-left: 0.75rem;
}

@media (max-width: 1199px) {
  .ndppc-site-header .container {
    max-width: 1360px;
  }

  .ndppc-navbar-brand {
    flex-basis: 400px;
    margin-right: 1.25rem;
  }

  .ndppc-navbar-brand img {
    max-width: 400px;
  }

  .ndppc-site-header .nav-link {
    padding: 0.58rem 0.65rem !important;
    font-size: 0.86rem;
  }
}

@media (max-width: 991px) {
  .ndppc-site-header .container {
    max-width: 100%;
  }

  .ndppc-navbar {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .ndppc-navbar-brand {
    flex: 1 1 auto;
    max-width: calc(100% - 74px);
    margin-right: 0.8rem;
  }

  .ndppc-navbar-brand img {
    max-width: 100%;
  }

  .ndppc-site-header .navbar-nav {
    flex-wrap: nowrap !important;
  }
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: calc(var(--ndppc-header-offset) + 24px);
}

body {
  margin: 0;
  color: var(--ndppc-copy);
  background:
    radial-gradient(circle at top left, rgba(140, 109, 49, 0.08), transparent 24%),
    linear-gradient(180deg, #faf8f2 0%, #f1ede3 100%);
  line-height: 1.65;
  padding-top: var(--ndppc-header-offset);
  overflow-x: hidden;
}

body,
button,
input,
select,
textarea {
  font-family: "Segoe UI", "Helvetica Neue", Arial, sans-serif;
}

h1,
h2,
h3,
h4,
h5,
h6,
.ndppc-brand-copy strong,
.heading-style-1 {
  font-family: Georgia, "Times New Roman", serif;
  letter-spacing: -0.02em;
}

img,
video {
  max-width: 100%;
  display: block;
}

a {
  color: var(--ndppc-primary);
  text-decoration: none;
}

a:hover {
  color: var(--ndppc-primary-dark);
}

button,
input,
select,
textarea {
  font: inherit;
}

main {
  display: block;
  min-height: calc(100vh - var(--ndppc-header-offset));
  scroll-margin-top: calc(var(--ndppc-header-offset) + 24px);
}

body .container {
  max-width: var(--ndppc-max);
}

.rounded-pill {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0.2rem 0.8rem;
  border-radius: 999px;
  background: var(--ndppc-accent-soft);
  color: #6c521f;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.ndppc-card-copy,
.ndppc-page-copy p,
.explore_head p,
.ndppc-copy-list li,
.ndppc-hero-slide p,
.footer p,
.footer li,
.footer a {
  color: var(--ndppc-copy-soft);
}

.ndppc-site-header {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1200;
}

.ndppc-site-header .header-top {
  background: #17382d;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.ndppc-site-header .header-top .row {
  min-height: 44px;
  align-items: center;
}

.goi a,
.ndppc-site-header .header-top a,
.ndppc-site-header .header-top strong,
.ndppc-site-header .header-top select,
.ndppc-site-header .header-top button,
.ndppc-site-header .header-top span,
.ndppc-site-header .header-top label {
  color: #fff !important;
}

.goi a {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.88rem;
  font-weight: 600;
}

.goi img {
  width: 22px;
  height: auto;
}

.partition {
  color: rgba(255, 255, 255, 0.45) !important;
}

.font01 {
  border: 0;
  background: transparent;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1;
  padding: 0;
}

.font01.active01 {
  color: #f4d992 !important;
}

.skip01 {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.9rem;
  font-weight: 600;
}

.ndppc-skip-link {
  margin-right: 1rem;
}

.skip01 img,
.language01 img {
  width: 18px;
  height: 18px;
}

.language01 form {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.language01 select {
  border: 0;
  background: transparent;
  font-size: 0.9rem;
  font-weight: 600;
}

.ndppc-datetime {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  margin-right: 0.95rem;
  font-size: 0.84rem;
  white-space: nowrap;
}

.ndppc-datetime::after {
  content: "";
  width: 1px;
  height: 16px;
  background: rgba(255, 255, 255, 0.25);
}

.ndppc-site-header .header-area {
  background: rgba(249, 247, 241, 0.97);
  border-bottom: 1px solid rgba(18, 44, 34, 0.08);
  backdrop-filter: blur(16px);
  transition: box-shadow 0.25s ease;
}

.sticky-bar {
  box-shadow: 0 0px 24px rgba(18, 44, 34, 0.1);
}

.ndppc-site-header .container-fluid {
  padding-left: 0;
  padding-right: 0;
}

.ndppc-site-header .navbar {
  padding: 0;
}

.ndppc-site-header .navbar-brand {
  min-width: 0;
  margin-right: 1rem;
}

.ndppc-brand {
  display: flex;
  align-items: center;
  gap: 0.95rem;
  min-width: 0;
}

.ndppc-brand-mark {
  width: 64px;
  height: 64px;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.65rem;
  border: 1px solid var(--ndppc-line);
  border-radius: 14px;
  background: #fff;
}

.ndppc-brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.ndppc-brand-copy {
  min-width: 0;
  display: grid;
  gap: 0.15rem;
}

.ndppc-brand-copy strong {
  display: block;
  font-size: 1.18rem;
  line-height: 1.15;
  color: var(--ndppc-primary-dark);
}

.ndppc-brand-copy span {
  font-size: 0.9rem;
  color: #56665f;
}

.ndppc-site-header .navbar-collapse {
  align-items: center;
}

.ndppc-site-header .navbar-nav {
  gap: 0.1rem;
}

.ndppc-site-header .nav-link,
.ndppc-site-header .dropdown-item {
  color: var(--ndppc-copy) !important;
  font-size: 0.95rem;
  font-weight: 600;
}

.ndppc-site-header .nav-link {
  padding: 0.95rem 0.85rem !important;
  border-radius: 10px;
}

.ndppc-site-header .nav-link.active,
.ndppc-site-header .nav-link:hover,
.ndppc-site-header .dropdown-item.active,
.ndppc-site-header .dropdown-item:hover {
  color: var(--ndppc-primary) !important;
  background: rgba(29, 75, 57, 0.07);
}

.ndppc-site-header .dropdown-menu {
  margin-top: 0.55rem;
  padding: 0.45rem;
  border: 1px solid rgba(18, 44, 34, 0.08);
  border-radius: 12px;
  box-shadow: 0 18px 32px rgba(18, 44, 34, 0.1);
}

.ndppc-header-tools {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-left: 1rem;
}

.ndppc-header-link a {
  width: 42px;
  height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(18, 44, 34, 0.12);
  border-radius: 10px;
  background: #fff;
}

.ndppc-header-tools .login-btn,
.ndppc-link-btn,
.footer_need_support .btn,
.view-all-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.7rem 1.1rem;
  border-radius: var(--ndppc-radius-sm);
  border: 1px solid var(--ndppc-primary);
  background: var(--ndppc-primary);
  color: #fff;
  font-weight: 700;
}

.ndppc-header-tools .login-btn:hover,
.ndppc-link-btn:hover,
.footer_need_support .btn:hover,
.view-all-btn:hover {
  background: var(--ndppc-primary-dark);
  border-color: var(--ndppc-primary-dark);
  color: #fff;
}

.ndppc-header-tools .login-btn {
  min-width: 146px;
}

.ndppc-outline-btn,
.ndppc-filter-row button,
.ndppc-tab-row button,
.ndppc-search-box input,
.ndppc-pill,
.ndppc-lightbox-close {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.7rem 1rem;
  border-radius: var(--ndppc-radius-sm);
  border: 1px solid rgba(18, 44, 34, 0.12);
  background: #fff;
  color: var(--ndppc-primary-dark);
  font-weight: 700;
}

.ndppc-outline-btn:hover,
.ndppc-filter-row button:hover,
.ndppc-tab-row button:hover,
.ndppc-lightbox-close:hover {
  background: rgba(29, 75, 57, 0.05);
  color: var(--ndppc-primary-dark);
}

.ndppc-filter-row button.active,
.ndppc-tab-row button.active {
  background: var(--ndppc-primary);
  border-color: var(--ndppc-primary);
  color: #fff;
}

.ndppc-pill {
  min-height: 38px;
  padding: 0.45rem 0.85rem;
  border-radius: 999px;
  font-size: 0.86rem;
  font-weight: 600;
}

.ndppc-action-row,
.ndppc-pill-row,
.ndppc-filter-row,
.ndppc-tab-row,
.ndppc-directory-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.ndppc-alert-strip {
  background: #e5ede6;
  border-bottom: 1px solid rgba(18, 44, 34, 0.08);
}

.ndppc-alert-strip-inner {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 1rem;
  min-height: 60px;
}

.ndppc-alert-strip strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.84rem;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.ndppc-alert-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem 1rem;
  min-width: 0;
}

.ndppc-alert-links a {
  color: var(--ndppc-copy);
  font-size: 0.92rem;
  font-weight: 600;
}

.ndppc-home-hero {
  padding: 42px 0 56px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.64), rgba(255, 255, 255, 0)),
    linear-gradient(135deg, rgba(29, 75, 57, 0.05), rgba(140, 109, 49, 0.07));
}

.ndppc-home-hero-grid,
.ndppc-page-hero-inner,
.ndppc-copy-grid,
.ndppc-support-grid,
.ndppc-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.5rem;
}

.ndppc-home-hero-grid {
  align-items: stretch;
}

.ndppc-home-lead,
.ndppc-page-copy,
.ndppc-page-media,
.ndppc-panel,
.ndppc-stat-card,
.ndppc-copy-card,
.ndppc-directory-card,
.ndppc-doc-card,
.ndppc-gallery-card,
.ndppc-link-card,
.ndppc-stage,
.ndppc-iframe-card,
.ndppc-tab-card,
.ndppc-home-link-card,
.ndppc-capability-card,
.ndppc-notice-card {
  background: var(--ndppc-card);
  border: 1px solid var(--ndppc-line);
  border-radius: var(--ndppc-radius);
  box-shadow: var(--ndppc-shadow);
}

.ndppc-home-lead,
.ndppc-panel,
.ndppc-stat-card,
.ndppc-copy-card,
.ndppc-directory-card,
.ndppc-doc-card,
.ndppc-link-card,
.ndppc-tab-card,
.ndppc-home-link-card,
.ndppc-capability-card,
.ndppc-notice-card {
  padding: 1.45rem;
}

.ndppc-home-lead {
  display: grid;
  gap: 1rem;
  align-content: start;
}

.ndppc-home-lead h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.5rem, 2.5vw, 2.40rem);
  line-height: 1.08;
}

.ndppc-home-lead p {
  margin: 0;
  max-width: 60ch;
  font-size: 1.02rem;
  color: var(--ndppc-copy-soft);
}

.ndppc-home-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.ndppc-home-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 0.9rem;
  border: 1px solid rgba(18, 44, 34, 0.1);
  border-radius: 999px;
  background: #f8f5ef;
  color: var(--ndppc-primary-dark);
  font-size: 0.88rem;
  font-weight: 600;
}

.ndppc-hero-stat-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

.ndppc-hero-stat {
  display: grid;
  gap: 0.35rem;
  padding: 1rem;
  border-radius: 12px;
  background: #f8f5ee;
  border-top: 3px solid var(--ndppc-accent);
}

.ndppc-hero-stat strong,
.ndppc-count {
  color: var(--ndppc-primary-dark);
  line-height: 1;
}

.ndppc-hero-stat strong {
  font-size: clamp(1.45rem, 2.6vw, 2rem);
}

.ndppc-count {
  font-size: clamp(1.85rem, 3vw, 2.8rem);
  font-family: Georgia, "Times New Roman", serif;
}

.ndppc-hero-stat span {
  color: var(--ndppc-copy-soft);
  font-size: 0.9rem;
  font-weight: 600;
}

.ndppc-home-hero-media,
.ndppc-home-hero-media .owl-carousel,
.ndppc-home-hero-media .owl-stage-outer,
.ndppc-home-hero-media .owl-stage,
.ndppc-home-hero-media .owl-item,
.ndppc-home-hero-media .item {
  height: 100%;
}

.ndppc-hero-slide {
  height: 100%;
  margin: 0;
  overflow: hidden;
}

.ndppc-hero-slide img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

.ndppc-hero-slide figcaption {
  display: grid;
  gap: 0.7rem;
  padding: 1.35rem;
}

.ndppc-hero-slide figcaption strong {
  color: var(--ndppc-accent);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.ndppc-hero-slide h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.45rem;
}

.ndppc-home-directory-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-content: start;
}

.ndppc-home-link-card {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  align-items: center;
  gap: 0.9rem;
  min-height: 96px;
  color: var(--ndppc-primary-dark);
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.ndppc-home-link-card .material-symbols-outlined {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: #edf3ee;
  color: var(--ndppc-primary);
}

.ndppc-shell {
  padding: 68px 0;
}

.ndppc-shell-muted {
  background: rgba(236, 231, 220, 0.75);
}

.ndppc-section-heading {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1rem;
  margin-bottom: 2rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(18, 44, 34, 0.08);
}

.ndppc-section-copy {
  max-width: 760px;
  display: grid;
  gap: 0.35rem;
}

.ndppc-section-copy h3,
.ndppc-page-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
}

.ndppc-section-copy h3 {
  font-size: clamp(1.7rem, 2.8vw, 2.35rem);
}

.ndppc-section-copy p {
  margin: 0;
}

.ndppc-section-link {
  flex: 0 0 auto;
}

.ndppc-card-grid,
.ndppc-stat-grid,
.ndppc-doc-grid,
.ndppc-link-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.25rem;
}

.ndppc-directory-grid,
.ndppc-gallery-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.25rem;
}

.ndppc-home-link-card,
.ndppc-panel,
.ndppc-stat-card,
.ndppc-copy-card,
.ndppc-directory-card,
.ndppc-doc-card,
.ndppc-gallery-card,
.ndppc-link-card,
.ndppc-tab-card,
.ndppc-capability-card,
.ndppc-notice-card,
.ndppc-page-copy,
.ndppc-page-media,
.ndppc-iframe-card,
.ndppc-stage {
  min-width: 0;
}

.ndppc-stat-card,
.ndppc-doc-card,
.ndppc-link-card,
.ndppc-directory-card,
.ndppc-tab-card,
.ndppc-capability-card,
.ndppc-notice-card {
  display: grid;
  gap: 0.95rem;
  align-content: start;
  height: 100%;
}

.ndppc-card-grid > *,
.ndppc-stat-grid > *,
.ndppc-doc-grid > *,
.ndppc-link-grid > *,
.ndppc-directory-grid > *,
.ndppc-gallery-grid > * {
  min-width: 0;
}

.ndppc-capability-symbol {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: #edf3ee;
  color: var(--ndppc-primary);
}

.ndppc-capability-symbol .material-symbols-outlined {
  font-size: 1.55rem;
}

.ndppc-tab-card img,
.ndppc-directory-card img,
.ndppc-gallery-card img,
.ndppc-gallery-card video,
.ndppc-link-card img,
.ndppc-page-media img,
.ndppc-stage img,
.ndppc-iframe-card iframe {
  width: 100%;
  border-radius: 12px;
}

.ndppc-tab-card img,
.ndppc-link-card img {
  aspect-ratio: 16 / 11;
  object-fit: cover;
}

.ndppc-directory-card img {
  aspect-ratio: 4 / 4.8;
  object-fit: cover;
}

.ndppc-gallery-card {
  padding: 0.9rem;
  cursor: pointer;
}

.ndppc-gallery-card img,
.ndppc-gallery-card video {
  aspect-ratio: 16 / 12;
  object-fit: cover;
}

.ndppc-notice-card small {
  color: var(--ndppc-accent);
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.ndppc-notice-card h3,
.ndppc-notice-card h5,
.ndppc-capability-card h3,
.ndppc-link-card h3,
.ndppc-doc-card h3,
.ndppc-tab-card h3,
.ndppc-directory-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.32rem;
}

.ndppc-notice-card p {
  margin: 0;
}

.ndppc-notice-card a {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  font-weight: 700;
  color: var(--ndppc-primary-dark) !important;
}

.ndppc-page-hero {
  padding: 48px 0 40px;
  background:
    linear-gradient(180deg, rgba(29, 75, 57, 0.04), rgba(29, 75, 57, 0)),
    linear-gradient(135deg, rgba(140, 109, 49, 0.05), rgba(255, 255, 255, 0.6));
  border-bottom: 1px solid rgba(18, 44, 34, 0.08);
}

.ndppc-page-hero-inner {
  grid-template-columns: minmax(0, 1fr) 360px;
  align-items: center;
}

.ndppc-page-copy {
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.ndppc-page-copy h1 {
  margin: 0.85rem 0 1rem;
  font-size: clamp(2rem, 3vw, 2.8rem);
  line-height: 1.12;
}

.ndppc-breadcrumbs {
  color: var(--ndppc-copy-soft);
  font-size: 0.9rem;
  margin-bottom: 0.8rem;
}

.ndppc-breadcrumbs a {
  color: var(--ndppc-primary);
}

.ndppc-page-media {
  padding: 0;
  overflow: hidden;
}

.ndppc-page-media img {
  aspect-ratio: 5 / 4;
  object-fit: cover;
}

.ndppc-stage {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 1.25rem;
  padding: 1.25rem;
}

.ndppc-stage-nav {
  display: grid;
  gap: 0.7rem;
}

.ndppc-stage-nav .ndppc-outline-btn {
  justify-content: flex-start;
  width: 100%;
  text-align: left;
}

.ndppc-stage-nav .ndppc-outline-btn.active {
  background: var(--ndppc-primary);
  border-color: var(--ndppc-primary);
  color: #fff;
}

.ndppc-stage-copy {
  display: grid;
  gap: 1rem;
}

.ndppc-stage-copy img {
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

body[data-page="infra"] .ndppc-infra-overview-band {
  padding-top: 28px;
  padding-bottom: 14px;
  background:
    linear-gradient(180deg, rgba(20, 53, 38, 0.04), rgba(20, 53, 38, 0)),
    linear-gradient(135deg, rgba(184, 146, 66, 0.08), rgba(255, 255, 255, 0.72));
}

body[data-page="infra"] .ndppc-infra-overview-grid {
  max-width: 1320px;
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(300px, 0.82fr);
  gap: 2rem;
  align-items: start;
}

body[data-page="infra"] .ndppc-infra-overview-copy {
  display: grid;
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-overview-copy h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.76rem, 2.45vw, 2.55rem);
  line-height: 1.08;
  max-width: 18ch;
}

body[data-page="infra"] .ndppc-infra-overview-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-core-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-sensor-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-stage-text .ndppc-card-copy {
  text-align: justify;
}

body[data-page="infra"] .ndppc-infra-overview-glance {
  display: grid;
  gap: 1rem;
  padding: 1.35rem 1.4rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(246, 240, 227, 0.88));
}

body[data-page="infra"] .ndppc-infra-glance-list {
  display: grid;
  gap: 0.9rem;
}

body[data-page="infra"] .ndppc-infra-glance-list article {
  display: grid;
  gap: 0.28rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="infra"] .ndppc-infra-glance-list article:first-child {
  padding-top: 0;
  border-top: 0;
}

body[data-page="infra"] .ndppc-infra-glance-list strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.6rem;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-glance-list span {
  color: var(--ndppc-copy);
  line-height: 1.75;
}

body[data-page="infra"] .ndppc-infra-core-band,
body[data-page="infra"] .ndppc-infra-sensor-band,
body[data-page="infra"] .ndppc-infra-browser-band {
  padding-top: 18px;
  padding-bottom: 14px;
}

body[data-page="infra"] .ndppc-infra-core-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.35rem;
}

body[data-page="infra"] .ndppc-infra-core-card {
  display: grid;
  grid-template-columns: minmax(200px, 0.86fr) minmax(0, 1.14fr);
  gap: 1.2rem;
  align-items: start;
  padding: 1.15rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.94);
}

body[data-page="infra"] .ndppc-infra-core-card img {
  width: 100%;
  aspect-ratio: 5 / 4;
  object-fit: cover;
}

body[data-page="infra"] .ndppc-infra-core-copy {
  display: grid;
  gap: 0.8rem;
}

body[data-page="infra"] .ndppc-infra-core-copy h3,
body[data-page="infra"] .ndppc-infra-sensor-copy h3,
body[data-page="infra"] .ndppc-infra-stage-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.24rem;
  line-height: 1.3;
}

body[data-page="infra"] .ndppc-infra-core-points,
body[data-page="infra"] .ndppc-infra-sensor-points,
body[data-page="infra"] .ndppc-infra-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

body[data-page="infra"] .ndppc-infra-sensor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.2rem;
}

body[data-page="infra"] .ndppc-infra-sensor-card {
  display: grid;
  grid-template-columns: 98px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 1rem 0;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
}

body[data-page="infra"] .ndppc-infra-sensor-card:nth-child(-n+2) {
  padding-top: 0;
  border-top: 0;
}

body[data-page="infra"] .ndppc-infra-sensor-media {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding-top: 0.15rem;
}

body[data-page="infra"] .ndppc-infra-sensor-media img {
  max-width: 84px;
  max-height: 84px;
  object-fit: contain;
}

body[data-page="infra"] .ndppc-infra-sensor-copy {
  display: grid;
  gap: 0.7rem;
}

body[data-page="infra"] .ndppc-infra-browser-stage {
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 1.3rem;
}

body[data-page="infra"] .ndppc-infra-browser-stage .ndppc-stage-nav {
  padding: 1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.92);
}

body[data-page="infra"] .ndppc-infra-browser-stage .ndppc-stage-nav .ndppc-outline-btn {
  min-height: 48px;
  justify-content: flex-start;
  text-align: left;
}

body[data-page="infra"] .ndppc-infra-browser-detail {
  padding: 1.15rem;
}

body[data-page="infra"] .ndppc-infra-stage-panel {
  display: grid;
  grid-template-columns: minmax(280px, 0.88fr) minmax(0, 1.12fr);
  gap: 1.3rem;
  align-items: start;
}

body[data-page="infra"] .ndppc-infra-stage-media img {
  width: 100%;
  aspect-ratio: 5 / 4;
  object-fit: cover;
}

body[data-page="infra"] .ndppc-infra-stage-copy {
  display: grid;
  gap: 0.85rem;
}

body[data-page="infra"] .ndppc-infra-stage-text {
  display: grid;
  gap: 0.75rem;
}

.ndppc-search-box input {
  width: 100%;
  justify-content: flex-start;
  font-weight: 500;
}

.ndppc-search-box input::placeholder {
  color: #7f8b84;
}

.ndppc-copy-list {
  margin: 0;
  padding-left: 1.1rem;
}

.ndppc-copy-list li + li {
  margin-top: 0.7rem;
}

.ndppc-iframe-card {
  overflow: hidden;
  padding: 0;
}

.ndppc-iframe-card iframe {
  min-height: 420px;
  border: 0;
}

.ndppc-map iframe {
  min-height: 420px;
}

.ndppc-lightbox {
  width: min(96vw, 1080px);
  padding: 1rem;
  border: 0;
  border-radius: var(--ndppc-radius);
  background: #fbf8f2;
  box-shadow: 0 24px 60px rgba(18, 44, 34, 0.2);
}

.ndppc-lightbox::backdrop {
  background: rgba(18, 44, 34, 0.7);
}

.ndppc-lightbox-content {
  display: grid;
  gap: 1rem;
}

.ndppc-lightbox-content img,
.ndppc-lightbox-content video {
  width: 100%;
  border-radius: 12px;
}

.ndppc-lightbox-close {
  margin-left: auto;
  margin-bottom: 1rem;
}

.accordion-item {
  border: 1px solid var(--ndppc-line);
  border-radius: 12px !important;
  overflow: hidden;
}

.accordion-item + .accordion-item {
  margin-top: 0.85rem;
}

.accordion-button {
  font-weight: 700;
  color: var(--ndppc-primary-dark);
  background: #fff;
}

.accordion-button:not(.collapsed) {
  color: var(--ndppc-primary-dark);
  background: #f7f4ed;
  box-shadow: none;
}

.accordion-body {
  color: var(--ndppc-copy-soft);
}

.ndppc-footer-cta {
  padding: 54px 0;
  background: linear-gradient(135deg, #183a2f, #214a39);
}

.ndppc-footer-cta-inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 1.25rem;
}

.ndppc-footer-cta h3 {
  margin: 0 0 0.65rem;
  color: #fff;
  font-size: clamp(1.7rem, 2.8vw, 2.3rem);
}

.ndppc-footer-cta p {
  margin: 0;
  max-width: 54ch;
  color: rgba(255, 255, 255, 0.88) !important;
}

.ndppc-footer {
  padding: 54px 0 42px;
  background: #ece7db;
}

.ndppc-footer-inner {
  display: grid !important;
  grid-template-columns: minmax(250px, 1.05fr) minmax(180px, 0.72fr) minmax(190px, 0.78fr) minmax(320px, 1.18fr);
  align-items: stretch;
  gap: 2rem;
}

.ndppc-footer-col {
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: 100%;
}

.ndppc-footer-col h3 {
  margin-bottom: 1rem;
  color: var(--ndppc-primary-dark);
  font-size: 1.25rem;
}

.ndppc-footer-col ul {
  margin: 0;
  padding-left: 1rem;
}

.ndppc-footer-col li + li {
  margin-top: 0.55rem;
}

.ndppc-footer-brand {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.ndppc-footer-brand img {
  width: 70px;
  height: 70px;
  object-fit: contain;
  padding: 0.6rem;
  border-radius: 14px;
  background: #fff;
  border: 1px solid var(--ndppc-line);
}

.ndppc-footer-brand strong {
  display: block;
  margin-bottom: 0.2rem;
  color: var(--ndppc-primary-dark);
}

.ndppc-footer-social {
  display: flex;
  gap: 0.5rem;
}

.ndppc-footer-social a {
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: rgba(29, 75, 57, 0.08);
  color: var(--ndppc-primary-dark);
}

.btn-last-update {
  border: 1px solid rgba(18, 44, 34, 0.12);
  background: rgba(255, 255, 255, 0.65);
  color: var(--ndppc-primary-dark);
  border-radius: 10px !important;
}

.ndppc-cluster {
  min-height: 210px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px dashed rgba(18, 44, 34, 0.15);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--ndppc-copy-soft);
}

.ndppc-footer-map {
  display: block;
  flex: 1 1 auto;
  width: 100%;
  min-height: 248px;
  margin-top: 0;
  border: 0;
  border-radius: 12px;
}

.ndppc-subfooter {
  padding: 1rem 0;
  background: #0f2b1e;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ndppc-subfooter .copyright,
.ndppc-subfooter a {
  color: rgba(255, 255, 255, 0.9);
}

.ndppc-subfooter ul {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ndppc-subfooter-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  flex-wrap: wrap;
}

.ndppc-subfooter .container > div,
.ndppc-subfooter-inner {
  gap: 0.8rem;
}

.ndppc-hero-carousel .owl-stage,
.ndppc-service-carousel .owl-stage,
.ndppc-national-carousel .owl-stage,
.ndppc-news-carousel .owl-stage,
.ndppc-global-carousel .owl-stage,
.ndppc-team-carousel .owl-stage {
  display: flex;
}

.ndppc-hero-carousel .owl-item,
.ndppc-service-carousel .owl-item,
.ndppc-national-carousel .owl-item,
.ndppc-news-carousel .owl-item,
.ndppc-global-carousel .owl-item,
.ndppc-team-carousel .owl-item {
  display: flex;
  height: auto;
}

.ndppc-hero-carousel .item,
.ndppc-service-carousel .item,
.ndppc-national-carousel .item,
.ndppc-news-carousel .item,
.ndppc-global-carousel .item,
.ndppc-team-carousel .item {
  width: 100%;
  display: flex;
}

.owl-theme .owl-nav {
  margin-top: 1.2rem;
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
}

.owl-theme .owl-nav [class*="owl-"] {
  width: 42px;
  height: 42px;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(18, 44, 34, 0.1) !important;
  border-radius: 10px !important;
  background: rgba(29, 75, 57, 0.08) !important;
  color: var(--ndppc-primary-dark) !important;
}

.owl-theme .owl-nav [class*="owl-"]:hover {
  background: rgba(29, 75, 57, 0.16) !important;
}

.owl-theme .owl-dots {
  margin-top: 0.9rem;
}

.owl-theme .owl-dots .owl-dot span {
  background: rgba(29, 75, 57, 0.2);
}

.owl-theme .owl-dots .owl-dot.active span {
  background: var(--ndppc-primary);
}

#uw-main {
  z-index: 1300;
}

#uw-main .ndppc-link-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 1199px) {
  .ndppc-home-hero-grid,
  .ndppc-page-hero-inner,
  .ndppc-copy-grid,
  .ndppc-support-grid,
  .ndppc-detail-grid,
  .ndppc-stage {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-overview-grid,
  body[data-page="infra"] .ndppc-infra-core-grid,
  body[data-page="infra"] .ndppc-infra-sensor-grid,
  body[data-page="infra"] .ndppc-infra-browser-stage,
  body[data-page="infra"] .ndppc-infra-stage-panel {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-overview-copy h2 {
    max-width: none;
  }

  .ndppc-directory-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .ndppc-footer-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  body[data-page="infra"] .ndppc-infra-overview-band,
  body[data-page="infra"] .ndppc-infra-core-band,
  body[data-page="infra"] .ndppc-infra-sensor-band,
  body[data-page="infra"] .ndppc-infra-browser-band {
    padding-top: 16px;
    padding-bottom: 10px;
  }

  body[data-page="infra"] .ndppc-infra-overview-copy h2 {
    font-size: 1.72rem;
  }

  body[data-page="infra"] .ndppc-infra-overview-glance,
  body[data-page="infra"] .ndppc-infra-core-card,
  body[data-page="infra"] .ndppc-infra-browser-detail,
  body[data-page="infra"] .ndppc-infra-browser-stage .ndppc-stage-nav {
    padding: 1rem;
  }

  body[data-page="infra"] .ndppc-infra-sensor-card {
    grid-template-columns: 1fr;
    gap: 0.75rem;
  }

  body[data-page="infra"] .ndppc-infra-sensor-card:nth-child(2) {
    padding-top: 1rem;
    border-top: 1px solid rgba(20, 53, 38, 0.1);
  }

  body[data-page="infra"] .ndppc-infra-sensor-media {
    justify-content: flex-start;
  }

  body[data-page="infra"] .ndppc-infra-sensor-media img {
    max-width: 74px;
    max-height: 74px;
  }
}

@media (max-width: 991px) {
  :root {
    --ndppc-header-offset: 126px;
  }

  .ndppc-datetime,
  .ndppc-header-tools {
    display: none;
  }

  .ndppc-site-header .navbar-brand {
    max-width: calc(100% - 64px);
  }

  .ndppc-site-header .navbar-toggler {
    border: 1px solid rgba(18, 44, 34, 0.12);
    border-radius: 10px;
    padding: 0.45rem 0.65rem;
  }

  .ndppc-site-header .navbar-toggler:focus {
    box-shadow: 0 0 0 0.2rem rgba(29, 75, 57, 0.12);
  }

  .ndppc-site-header .navbar-toggler-icon {
    width: 1.35rem;
    height: 1.35rem;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2818,44,34,0.88%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
  }

  .ndppc-site-header .navbar-collapse {
    margin-top: 1rem;
    padding: 1rem;
    border: 1px solid rgba(18, 44, 34, 0.08);
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.98);
    box-shadow: var(--ndppc-shadow);
  }

  .ndppc-site-header .navbar-nav {
    gap: 0.35rem;
  }

  .ndppc-site-header .nav-link {
    padding: 0.8rem 0.85rem !important;
  }

  .ndppc-site-header .dropdown-menu {
    margin-top: 0.25rem;
    box-shadow: none;
    border-color: rgba(18, 44, 34, 0.06);
  }

  .ndppc-stat-grid,
  .ndppc-card-grid,
  .ndppc-doc-grid,
  .ndppc-link-grid,
  .ndppc-directory-grid,
  .ndppc-gallery-grid,
  .ndppc-home-directory-grid,
  .ndppc-hero-stat-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ndppc-home-lead h1 {
    font-size: 1.95rem;
  }

  .ndppc-footer-cta-inner {
    align-items: flex-start;
  }
}

@media (max-width: 767px) {
  :root {
    --ndppc-header-offset: 108px;
  }

  .ndppc-site-header .header-top .container,
  .ndppc-site-header .header-area .container,
  .ndppc-shell .container,
  .ndppc-page-hero .container,
  .ndppc-home-hero .container,
  .ndppc-alert-strip .container,
  .ndppc-footer .container,
  .ndppc-subfooter .container,
  .ndppc-footer-cta .container {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .goi a {
    font-size: 0.8rem;
  }

  .ndppc-site-header .header-top .row {
    min-height: auto;
    padding: 0.4rem 0;
  }

  .ndppc-site-header .header-top .text-end {
    display: flex;
    justify-content: flex-end;
    align-items: center;
  }

  .language01,
  .skip01 strong {
    display: none !important;
  }

  .ndppc-brand {
    align-items: flex-start;
  }

  .ndppc-brand-mark {
    width: 54px;
    height: 54px;
  }

  .ndppc-brand-copy strong {
    font-size: 1rem;
  }

  .ndppc-brand-copy span {
    font-size: 0.82rem;
  }

  .ndppc-alert-strip-inner {
    grid-template-columns: 1fr;
    align-items: flex-start;
    padding: 0.85rem 0;
  }

  .ndppc-home-hero {
    padding: 30px 0 40px;
  }

  .ndppc-home-lead,
  .ndppc-panel,
  .ndppc-stat-card,
  .ndppc-copy-card,
  .ndppc-directory-card,
  .ndppc-doc-card,
  .ndppc-link-card,
  .ndppc-tab-card,
  .ndppc-home-link-card,
  .ndppc-capability-card,
  .ndppc-notice-card {
    padding: 1.15rem;
  }

  .ndppc-home-lead h1 {
    font-size: 1.6rem;
  }

  .ndppc-shell {
    padding: 54px 0;
  }

  .ndppc-page-hero {
    padding: 34px 0 30px;
  }

  .ndppc-section-heading {
    align-items: flex-start;
  }

  .ndppc-stat-grid,
  .ndppc-card-grid,
  .ndppc-doc-grid,
  .ndppc-link-grid,
  .ndppc-directory-grid,
  .ndppc-gallery-grid,
  .ndppc-home-directory-grid,
  .ndppc-hero-stat-row,
  .ndppc-footer-inner,
  #uw-main .ndppc-link-grid {
    grid-template-columns: 1fr;
  }

  .ndppc-subfooter ul {
    justify-content: center;
  }

  .ndppc-footer-cta-inner,
  .ndppc-subfooter-inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Final Header And Overlap Override */
.ndppc-site-header .container {
  max-width: 1460px;
  width: 100%;
}

.ndppc-site-header .header-top {
  padding: 0;
}

.ndppc-topbar-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  min-height: 42px;
  white-space: nowrap;
  flex-wrap: nowrap;
}

.ndppc-topbar-left,
.ndppc-topbar-right {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  min-width: 0;
}

.ndppc-topbar-left {
  flex: 1 1 auto;
  overflow: hidden;
}

.ndppc-topbar-right {
  flex: 0 0 auto;
}

.ndppc-topbar-left .goi,
.ndppc-topbar-left .goi a,
.ndppc-topbar-skip,
.ndppc-topbar-reader strong {
  white-space: nowrap;
}

.ndppc-navbar {
  padding: 0.9rem 0.35rem !important;
}

.ndppc-navbar-brand {
  display: inline-flex;
  align-items: center;
  flex: 0 1 390px;
  min-width: 0;
  margin-right: 1.75rem;
}

.ndppc-navbar-brand img {
  width: 100%;
  max-width: 390px;
  height: auto;
  display: block;
}

.ndppc-site-header .container-fluid {
  display: flex;
  align-items: center;
  gap: 1.35rem;
}

.ndppc-site-header .navbar-collapse {
  flex: 1 1 auto;
  justify-content: flex-end;
  min-width: 0;
}

.ndppc-site-header .navbar-nav {
  flex-wrap: nowrap !important;
  justify-content: flex-end;
  gap: 0.14rem;
}

.ndppc-site-header .nav-link {
  padding: 0.6rem 0.78rem !important;
  font-size: 0.9rem;
  white-space: nowrap;
}

.ndppc-header-tools {
  margin-left: 0.75rem;
  flex-shrink: 0;
}

.ndppc-header-link {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
  min-height: 44px;
  padding: 0.65rem 0.95rem;
  border: 1px solid rgba(184, 146, 66, 0.42);
  border-radius: 999px;
  background: linear-gradient(135deg, #f6edd4 0%, #ead29a 100%);
  color: #3f3114 !important;
  font-weight: 700;
  box-shadow: 0 10px 22px rgba(184, 146, 66, 0.16);
}

.ndppc-header-link .material-symbols-outlined {
  font-size: 1.05rem;
  color: #7f5d10;
}

.ndppc-header-link:hover {
  background: linear-gradient(135deg, #f0e0b0 0%, #e2c372 100%);
  border-color: rgba(184, 146, 66, 0.55);
  color: #2f240e !important;
}

.ndppc-header-tools > .ndppc-header-link:first-of-type {
  justify-content: center;
  width: 44px;
  height: 44px;
  min-height: 44px;
  padding: 0;
  border-color: rgba(18, 44, 34, 0.14);
  background: rgba(255, 255, 255, 0.98);
  color: var(--ndppc-primary-dark) !important;
  box-shadow: 0 10px 22px rgba(18, 44, 34, 0.08);
}

.ndppc-header-tools > .ndppc-header-link:first-of-type .material-symbols-outlined {
  font-size: 1.2rem;
  color: var(--ndppc-primary);
}

.ndppc-header-tools > .ndppc-header-link:first-of-type:hover {
  background: rgba(29, 75, 57, 0.08);
  border-color: rgba(18, 44, 34, 0.2);
  color: var(--ndppc-primary-dark) !important;
}

.ndppc-header-tools > .ndppc-header-link:first-of-type:focus-visible,
.ndppc-header-tools > .ndppc-header-link:first-of-type:active {
  background: #1d4b39;
  border-color: #1d4b39;
  color: #fff !important;
  box-shadow: 0 10px 22px rgba(18, 44, 34, 0.18);
}

.ndppc-header-tools > .ndppc-header-link:first-of-type:focus-visible .material-symbols-outlined,
.ndppc-header-tools > .ndppc-header-link:first-of-type:active .material-symbols-outlined {
  color: #fff;
}

.ndppc-header-search {
  position: relative;
  width: auto;
}

.ndppc-search-trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  padding: 0;
  border: 1px solid rgba(18, 44, 34, 0.12);
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 10px 22px rgba(18, 44, 34, 0.08);
}

.ndppc-search-trigger:hover,
.ndppc-header-search.is-open .ndppc-search-trigger {
  background: rgba(29, 75, 57, 0.08);
  border-color: rgba(18, 44, 34, 0.18);
}

.ndppc-search-trigger .material-symbols-outlined {
  font-size: 1.2rem;
  color: var(--ndppc-primary);
}

.ndppc-search-panel {
  position: absolute;
  top: calc(100% + 0.55rem);
  right: 0;
  width: min(420px, 40vw);
  padding: 0.7rem;
  border: 1px solid rgba(18, 44, 34, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.99);
  box-shadow: 0 24px 42px rgba(18, 44, 34, 0.14);
  z-index: 40;
}

.ndppc-search-panel[hidden] {
  display: none !important;
}

.ndppc-header-search .ndppc-search-form {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  min-height: 44px;
  padding: 0.35rem 0.8rem;
  border: 1px solid rgba(18, 44, 34, 0.1);
  border-radius: 14px;
  background: #f7f4ed;
  box-shadow: none;
}

.ndppc-header-search .ndppc-search-form .material-symbols-outlined {
  flex: 0 0 auto;
  font-size: 1.1rem;
  color: var(--ndppc-primary);
}

.ndppc-header-search .ndppc-search-input {
  width: 100%;
  min-width: 0;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--ndppc-primary-dark);
  font-size: 0.92rem;
  font-weight: 500;
  outline: 0;
  box-shadow: none;
}

.ndppc-header-search .ndppc-search-input::placeholder {
  color: #77847b;
}

.ndppc-search-clear {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  padding: 0;
  border: 0;
  border-radius: 50%;
  background: rgba(29, 75, 57, 0.08);
  color: var(--ndppc-primary-dark);
}

.ndppc-search-clear[hidden] {
  display: none !important;
}

.ndppc-search-results {
  position: static;
  width: 100%;
  max-height: min(58vh, 440px);
  overflow: auto;
  margin-top: 0.7rem;
  padding: 0.7rem 0 0;
  border-top: 1px solid rgba(18, 44, 34, 0.08);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  z-index: auto;
}

.ndppc-search-results-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.15rem 0.2rem 0.75rem;
}

.ndppc-search-results-head strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.95rem;
}

.ndppc-search-results-head span {
  color: var(--ndppc-copy-soft);
  font-size: 0.8rem;
}

.ndppc-search-results-list {
  display: grid;
  gap: 0.5rem;
}

.ndppc-search-result {
  display: grid;
  gap: 0.28rem;
  padding: 0.85rem 0.95rem;
  border: 1px solid rgba(18, 44, 34, 0.08);
  border-radius: 14px;
  background: #fff;
  color: inherit;
  transition: border-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.ndppc-search-result:hover {
  transform: translateY(-1px);
  border-color: rgba(18, 44, 34, 0.16);
  box-shadow: 0 14px 24px rgba(18, 44, 34, 0.08);
}

.ndppc-search-result small {
  color: var(--ndppc-primary);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.ndppc-search-result strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.96rem;
  line-height: 1.4;
}

.ndppc-search-result span {
  color: var(--ndppc-copy-soft);
  font-size: 0.83rem;
  line-height: 1.5;
}

.ndppc-search-empty {
  display: grid;
  gap: 0.35rem;
  padding: 0.35rem 0.2rem;
}

.ndppc-search-empty strong {
  color: var(--ndppc-primary-dark);
}

.ndppc-search-empty p {
  margin: 0;
  color: var(--ndppc-copy-soft);
  font-size: 0.86rem;
}

@media (max-width: 1399px) {
  .ndppc-search-panel {
    width: min(380px, 42vw);
  }
}

@media (max-width: 1279px) {
  .ndppc-search-panel {
    width: min(340px, 46vw);
  }
}

.footer_need_support.ndppc-footer-cta {
  margin-top: 0;
}

.ndppc-footer-cta-inner {
  transform: none !important;
}

.ndppc-footer {
  padding-top: 48px;
}

.owl-carousel .owl-stage {
  display: flex;
  align-items: stretch;
}

.owl-carousel .owl-item {
  float: none;
  display: flex;
  height: auto;
}

.owl-carousel .item {
  width: 100%;
  height: 100%;
}

.application-card,
.news-card,
.counter-box,
.services_card,
.services_card_inner,
.ndppc-project-card,
.ndppc-doc-card,
.ndppc-link-card,
.ndppc-facility-card,
.ndppc-person-card {
  height: 100%;
}

@media (max-width: 1199px) {
  .ndppc-site-header .container {
    max-width: 1360px;
  }

  .ndppc-navbar-brand {
    flex-basis: 340px;
    margin-right: 1rem;
  }

  .ndppc-navbar-brand img {
    max-width: 340px;
  }

  .ndppc-site-header .nav-link {
    padding: 0.58rem 0.65rem !important;
    font-size: 0.86rem;
  }

  .ndppc-topbar-reader strong {
    display: none;
  }
}

@media (max-width: 991px) {
  .ndppc-site-header .container {
    max-width: 100%;
  }

  .ndppc-topbar-right {
    display: none;
  }

  .ndppc-navbar {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  .ndppc-navbar-brand {
    flex: 1 1 auto;
    max-width: calc(100% - 74px);
    margin-right: 0.8rem;
  }

  .ndppc-navbar-brand img {
    max-width: 100%;
  }

  .ndppc-site-header .container-fluid {
    gap: 0.65rem;
  }
}

@media (max-width: 767px) {
  .ndppc-topbar-skip,
  .ndppc-topbar-divider {
    display: none;
  }

  .ndppc-topbar-left .goi strong {
    max-width: calc(100vw - 80px);
    overflow: hidden;
    text-overflow: ellipsis;
    display: inline-block;
    vertical-align: middle;
  }
}

/* Scroll Hide Utility Strip */
.ndppc-site-header .header-top {
  overflow: hidden;
  max-height: 48px;
  opacity: 1;
  transition: max-height 0.25s ease, opacity 0.2s ease, border-color 0.2s ease;
}

.ndppc-site-header.is-scrolled .header-top {
  max-height: 0;
  opacity: 0;
  border-bottom-color: transparent;
}

.ndppc-site-header.is-scrolled .ndppc-topbar-line {
  min-height: 0;
}

/* Final Logo Inset Fix */
.ndppc-site-header .container-fluid {
  padding-left: 0.9rem !important;
  padding-right: 0.4rem !important;
}

.ndppc-navbar-brand {
  padding-left: 0.15rem;
}

@media (max-width: 991px) {
  .ndppc-site-header .container-fluid {
    padding-left: 0.55rem !important;
    padding-right: 0.2rem !important;
  }

  .ndppc-navbar-brand {
    padding-left: 0;
  }
}

/* Final Text Brand Override */
.ndppc-navbar-brand {
  flex: 0 1 500px !important;
  margin-right: 1.5rem !important;
}

.ndppc-brand-lockup {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  min-width: 0;
}

.ndppc-brand-logo {
  width: 58px;
  height: 58px;
  flex: 0 0 58px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.ndppc-brand-logo img {
  width: 100%;
  height: 100%;
  max-width: none !important;
  object-fit: contain;
  display: block;
}

.ndppc-navbar-brand .ndppc-brand-copy {
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
  min-width: 0;
}

.ndppc-navbar-brand .ndppc-brand-copy strong {
  font-family: "Lexend Deca", "Noto Sans", sans-serif !important;
  font-size: 1.2rem;
  line-height: 1.12;
  color: var(--ndppc-primary);
}

.ndppc-navbar-brand .ndppc-brand-copy small {
  font-size: 0.84rem;
  line-height: 1.18;
  color: var(--ndppc-copy-soft);
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

@media (max-width: 1199px) {
  .ndppc-navbar-brand {
    flex-basis: 440px !important;
    margin-right: 1rem !important;
  }

  .ndppc-brand-logo {
    width: 52px;
    height: 52px;
    flex-basis: 52px;
  }

  .ndppc-navbar-brand .ndppc-brand-copy strong {
    font-size: 1.06rem;
  }

  .ndppc-navbar-brand .ndppc-brand-copy small {
    font-size: 0.74rem;
  }
}

@media (max-width: 991px) {
  .ndppc-navbar-brand {
    flex: 1 1 auto !important;
    max-width: calc(100% - 82px) !important;
    margin-right: 0.75rem !important;
  }

  .ndppc-brand-lockup {
    gap: 0.65rem;
    align-items: center;
  }

  .ndppc-brand-logo {
    width: 48px;
    height: 48px;
    flex-basis: 48px;
  }

  .ndppc-navbar-brand .ndppc-brand-copy strong {
    font-size: 1.04rem;
  }

  .ndppc-navbar-brand .ndppc-brand-copy small {
    display: block;
    font-size: 0.72rem;
    line-height: 1.16;
    white-space: normal;
  }
}

@media (max-width: 575px) {
  .ndppc-navbar-brand {
    max-width: calc(100% - 72px) !important;
  }

  .ndppc-brand-logo {
    width: 42px;
    height: 42px;
    flex-basis: 42px;
  }

  .ndppc-navbar-brand .ndppc-brand-copy {
    gap: 0.12rem;
  }

  .ndppc-navbar-brand .ndppc-brand-copy strong {
    font-size: 0.94rem;
    line-height: 1.1;
  }

  .ndppc-navbar-brand .ndppc-brand-copy small {
    font-size: 0.66rem;
    letter-spacing: 0.02em;
  }
}

/* Final Translate And Sticky Shadow Override */
.ndppc-translate-host {
  position: fixed !important;
  top: 0 !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.sticky-bar,
.ndppc-site-header.is-scrolled .header-area {
  box-shadow: none !important;
}

@media (min-width: 992px) {
  .ndppc-site-header.is-scrolled {
    background: transparent !important;
  }

  .ndppc-site-header.is-scrolled .header-area,
  #header-sticky.sticky-bar {
    background: transparent !important;
    border-bottom-color: transparent !important;
    backdrop-filter: none !important;
  }
}

/* Final Minimized UX4G Accessibility */
.ndppc-access-panel {
  top: auto !important;
  right: var(--ndppc-ux4g-right, -530px) !important;
  bottom: 0 !important;
  width: min(480px, calc(100vw - 1rem)) !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  z-index: 9999 !important;
}

.ndppc-topbar-reader {
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  min-width: 34px;
  padding: 0 !important;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.22);
  line-height: 1;
}

.ndppc-topbar-reader strong {
  display: none !important;
}

.ndppc-topbar-reader img {
  width: 16px;
  height: 16px;
  display: block;
}

@media (max-width: 991px) {
  .ndppc-topbar-line {
    flex-wrap: nowrap;
    gap: 0.5rem;
  }

  .ndppc-topbar-left {
    flex: 1 1 auto;
    min-width: 0;
  }

  .ndppc-topbar-right {
    display: inline-flex !important;
    align-items: center;
    flex: 0 0 auto;
    margin-left: auto;
    gap: 0.45rem !important;
  }

  .ndppc-font-tools,
  .language01,
  .ndppc-topbar-reader,
  .ndppc-topbar-right .partition {
    display: none !important;
  }

  .ndppc-datetime {
    display: inline-flex !important;
    align-items: center;
    gap: 0.35rem;
    margin-right: 0;
    font-size: 0.75rem;
    line-height: 1;
    white-space: nowrap;
  }

  .ndppc-datetime::after {
    display: none;
  }

  .ndppc-topbar-left .goi strong {
    max-width: calc(100vw - 185px);
    overflow: hidden;
    text-overflow: ellipsis;
    display: inline-block;
  }
}

@media (max-width: 575px) {
  .ndppc-datetime {
    font-size: 0.68rem;
  }

  .ndppc-datetime #time-label {
    display: none;
  }

  .ndppc-topbar-left .goi strong {
    max-width: calc(100vw - 125px);
  }
}

/* Homepage Body Redesign */
.ndppc-home-hero-grid {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  padding: 0;
  grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
}

.ndppc-home-hero-grid .ndppc-home-lead,
.ndppc-home-hero-grid .ndppc-page-media {
  background: transparent;
  border: 0;
  box-shadow: none;
}

.ndppc-home-hero-grid .ndppc-home-lead {
  padding: 0;
}

.ndppc-home-link-copy {
  min-width: 0;
  display: grid;
  gap: 0.2rem;
}

.ndppc-home-lead-copy {
  display: grid;
  gap: 0.9rem;
}

.ndppc-home-lead-copy .ndppc-card-copy {
  text-align: justify;
}

.ndppc-home-link-copy strong {
  display: block;
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
}

.ndppc-home-link-copy small {
  display: block;
  color: var(--ndppc-copy-soft);
  font-size: 0.84rem;
  line-height: 1.45;
}

.ndppc-home-gateway-section {
  padding-top: 0;
}

.ndppc-home-gateway-panel {
  display: grid;
  gap: 1.25rem;
  padding: 1.45rem;
}

.ndppc-home-hero-aside,
.ndppc-home-focus-grid,
.ndppc-home-network-stack {
  display: grid;
  gap: 1.25rem;
}

.ndppc-home-brief-grid,
.ndppc-home-support-grid,
.ndppc-home-network-grid {
  display: grid;
  gap: 1.5rem;
  align-items: start;
}

.ndppc-home-brief-grid {
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
}

.ndppc-home-support-grid {
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
}

.ndppc-home-network-grid {
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
}

.ndppc-home-focus-grid,
.ndppc-home-resource-grid,
.ndppc-home-person-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
}

.ndppc-home-narrative {
  align-content: start;
}

.ndppc-home-narrative p {
  margin: 0;
}

.ndppc-home-stat-grid {
  margin-top: 1.5rem;
}

.ndppc-home-carousel-panel {
  padding: 1.35rem;
}

.ndppc-home-section-intro {
  display: grid;
  gap: 0.35rem;
  margin-bottom: 1rem;
}

.ndppc-home-section-intro h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.38rem;
}

.ndppc-home-section-intro p {
  margin: 0;
  color: var(--ndppc-copy-soft);
}

.ndppc-home-notice-card {
  padding: 1.45rem;
}

.ndppc-home-notice-card .material-symbols-outlined {
  font-size: 1rem;
}

.ndppc-home-hero-aside .ndppc-page-media {
  padding: 0;
  overflow: hidden;
}

.ndppc-home-hero-aside .ndppc-page-media .owl-carousel,
.ndppc-home-hero-aside .ndppc-page-media .owl-stage-outer,
.ndppc-home-hero-aside .ndppc-page-media .owl-stage,
.ndppc-home-hero-aside .ndppc-page-media .owl-item,
.ndppc-home-hero-aside .ndppc-page-media .item {
  height: 100%;
}

.ndppc-home-access-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 0.85rem;
}

.ndppc-home-access-list li {
  display: grid;
  gap: 0.22rem;
  padding-bottom: 0.8rem;
  border-bottom: 1px solid var(--ndppc-line);
}

.ndppc-home-access-list li:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.ndppc-home-access-list strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.ndppc-home-access-list span,
.ndppc-home-access-list a {
  color: var(--ndppc-copy-soft) !important;
}

.ndppc-home-map-card {
  display: grid;
  gap: 1rem;
  align-content: start;
  padding: 1.45rem;
}

.ndppc-home-map-card iframe {
  width: 100%;
  min-height: 320px;
  border: 0;
  border-radius: 12px;
}

@media (max-width: 1199px) {
  .ndppc-home-brief-grid,
  .ndppc-home-support-grid,
  .ndppc-home-network-grid {
    grid-template-columns: 1fr;
  }

  .ndppc-home-hero-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991px) {
  .ndppc-home-focus-grid,
  .ndppc-home-resource-grid,
  .ndppc-home-person-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .ndppc-home-hero-grid {
    padding: 1.15rem;
  }

  .ndppc-home-focus-grid,
  .ndppc-home-resource-grid,
  .ndppc-home-person-grid {
    grid-template-columns: 1fr;
  }

  .ndppc-home-link-card {
    min-height: auto;
  }

  .ndppc-home-map-card iframe {
    min-height: 260px;
  }
}

/* Final Owl Slider Shell */
.ndppc-home-hero-media .owl-carousel,
.ndppc-project-carousel,
.ndppc-national-carousel,
.ndppc-global-carousel,
.ndppc-team-carousel,
.ndppc-importance-carousel {
  position: relative;
  width: 100%;
}

.ndppc-home-hero-media .owl-stage-outer,
.ndppc-project-carousel .owl-stage-outer,
.ndppc-national-carousel .owl-stage-outer,
.ndppc-global-carousel .owl-stage-outer,
.ndppc-team-carousel .owl-stage-outer,
.ndppc-importance-carousel .owl-stage-outer {
  width: 100%;
  overflow: hidden;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.ndppc-home-hero-media .owl-stage,
.ndppc-project-carousel .owl-stage,
.ndppc-national-carousel .owl-stage,
.ndppc-global-carousel .owl-stage,
.ndppc-team-carousel .owl-stage,
.ndppc-importance-carousel .owl-stage {
  display: flex;
  align-items: stretch;
}

.ndppc-home-hero-media .owl-item,
.ndppc-project-carousel .owl-item,
.ndppc-national-carousel .owl-item,
.ndppc-global-carousel .owl-item,
.ndppc-team-carousel .owl-item,
.ndppc-importance-carousel .owl-item {
  display: flex;
  height: auto;
}

.ndppc-home-hero-media .owl-item .item,
.ndppc-project-carousel .owl-item .item,
.ndppc-national-carousel .owl-item .item,
.ndppc-global-carousel .owl-item .item,
.ndppc-team-carousel .owl-item .item,
.ndppc-importance-carousel .owl-item .item {
  display: flex;
  width: 100%;
  height: 100%;
}

.ndppc-home-hero-media .ndppc-hero-slide,
.ndppc-project-carousel .ndppc-project-card,
.ndppc-national-carousel .ndppc-facility-card,
.ndppc-global-carousel .ndppc-facility-card,
.ndppc-team-carousel .ndppc-person-card,
.ndppc-importance-carousel .ndppc-importance-card {
  width: 100%;
  height: 100%;
  margin: 0;
}

.ndppc-home-hero-media .ndppc-hero-slide img {
  width: 100%;
  height: clamp(300px, 34vw, 440px);
  display: block;
  object-fit: cover;
}

.ndppc-importance-card img,
.ndppc-project-card-media img,
.ndppc-facility-media img,
.ndppc-person-card-media img {
  width: 100%;
  display: block;
  object-fit: cover;
}

@media (max-width: 991px) {
  .ndppc-home-hero-media .owl-stage-outer,
  .ndppc-project-carousel .owl-stage-outer,
  .ndppc-national-carousel .owl-stage-outer,
  .ndppc-global-carousel .owl-stage-outer,
  .ndppc-team-carousel .owl-stage-outer,
  .ndppc-importance-carousel .owl-stage-outer {
    border-radius: 0;
  }

  .ndppc-home-hero-media .ndppc-hero-slide img {
    height: 280px;
  }
}

@media (max-width: 767px) {
  .ndppc-home-hero-media .owl-stage-outer,
  .ndppc-project-carousel .owl-stage-outer,
  .ndppc-national-carousel .owl-stage-outer,
  .ndppc-global-carousel .owl-stage-outer,
  .ndppc-team-carousel .owl-stage-outer,
  .ndppc-importance-carousel .owl-stage-outer {
    border-radius: 0;
  }

  .ndppc-home-hero-media .ndppc-hero-slide img {
    height: 240px;
  }
}

/* Final Home Banner Override */
body[data-page="home"] .banner.ndppc-home-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="home"] .ndppc-shell .container,
body[data-page="home"] .ndppc-alert-strip .container {
  max-width: 1320px;
}

.banner.ndppc-home-banner {
  padding-top: 0;
  padding-bottom: 6px;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

.banner.ndppc-home-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

.banner_content.ndppc-home-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
  gap: 0;
  align-items: stretch;
}

.ndppc-home-banner-panel {
  display: grid;
  gap: 0;
  min-height: 100%;
  width: 100%;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  position: relative;
  overflow: hidden;
}

.ndppc-home-banner .owl-carousel {
  position: relative;
  width: 100%;
  border-radius: 0;
  overflow: hidden;
}

.ndppc-home-banner .owl-stage-outer {
  width: 100%;
  overflow: hidden;
  border-radius: 0;
}

.ndppc-home-banner .owl-stage,
.ndppc-home-banner .owl-item,
.ndppc-home-banner .owl-item .item {
  display: flex;
  height: 100%;
}

.ndppc-home-banner .owl-item .item {
  width: 100%;
}

.ndppc-home-banner .ndppc-hero-slide {
  width: 100%;
  margin: 0;
  min-height: clamp(400px, 40vw, 575px);
  position: relative;
  border-radius: 0;
  overflow: hidden;
  background: #d8d2c4;
}

.ndppc-home-banner .ndppc-hero-slide::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(90deg, rgba(18, 44, 34, 0.68) 0%, rgba(18, 44, 34, 0.34) 38%, rgba(18, 44, 34, 0.08) 68%, rgba(18, 44, 34, 0.18) 100%),
    linear-gradient(180deg, rgba(12, 24, 19, 0.12) 0%, rgba(12, 24, 19, 0) 32%, rgba(12, 24, 19, 0.22) 100%);
}

.ndppc-home-banner .ndppc-hero-slide::after {
  content: none;
}

.ndppc-home-banner .ndppc-hero-slide img {
  width: 100%;
  height: clamp(400px, 40vw, 575px);
  display: block;
  object-fit: cover;
  object-position: center center;
}

.ndppc-home-banner .ndppc-hero-slide figcaption {
  position: absolute;
  left: 2rem;
  right: auto;
  top: auto;
  bottom: 2rem;
  transform: none;
  z-index: 2;
  display: grid;
  gap: 0.85rem;
  width: min(620px, calc(100% - 4rem));
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

.ndppc-home-banner .ndppc-banner-caption-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
}

.ndppc-home-banner .ndppc-banner-caption-top strong {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0.24rem 0.8rem;
  border-radius: 999px;
  background: #f5ecd7;
  color: #7a5e25;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.ndppc-home-banner .ndppc-banner-slide-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 46px;
  height: 46px;
  padding: 0 0.8rem;
  border-radius: 999px;
  background: var(--ndppc-primary);
  border: 1px solid var(--ndppc-primary);
  color: #fff;
  font-family: Georgia, "Times New Roman", serif;
  font-size: 1rem;
  font-weight: 700;
}

.ndppc-home-banner .ndppc-hero-slide h3 {
  margin: 0;
  color: #fff;
  font-size: clamp(1.9rem, 3.4vw, 3.2rem);
  line-height: 1.08;
  text-shadow: 0 8px 24px rgba(0, 0, 0, 0.24);
}

.ndppc-home-banner .ndppc-hero-slide p {
  margin: 0;
  max-width: 54ch;
  color: rgba(255, 255, 255, 0.92);
  font-size: 1.02rem;
  line-height: 1.5;
  text-shadow: 0 6px 18px rgba(0, 0, 0, 0.2);
}

.ndppc-home-banner .ndppc-banner-caption-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.ndppc-home-banner .ndppc-link-btn {
  min-height: 44px;
  padding: 0.75rem 1.15rem;
  background: var(--ndppc-primary);
  border: 1px solid var(--ndppc-primary);
  color: #fff !important;
}

.ndppc-home-banner .ndppc-link-btn:hover {
  background: var(--ndppc-primary-dark);
  border-color: var(--ndppc-primary-dark);
  color: #fff !important;
}

.ndppc-home-banner .owl-theme .owl-nav {
  position: absolute;
  inset: 50% 0 auto 0;
  transform: translateY(-50%);
  display: flex;
  justify-content: space-between;
  padding: 0 1.6rem;
  margin: 0;
  pointer-events: none;
}

.ndppc-home-banner .owl-theme .owl-nav [class*="owl-"] {
  width: 50px;
  height: 50px;
  margin: 0 !important;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  border-radius: 50% !important;
  border: 1px solid rgba(20, 53, 38, 0.12) !important;
  background: rgba(255, 255, 255, 0.92) !important;
  color: var(--ndppc-primary-dark) !important;
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.1);
  pointer-events: auto;
}

.ndppc-home-banner .owl-theme .owl-nav [class*="owl-"]:hover {
  background: #fff !important;
}

.ndppc-home-banner .owl-theme .owl-dots {
  position: absolute;
  right: 1.8rem;
  bottom: 0.8rem;
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0;
}

.ndppc-home-banner .owl-theme .owl-dots .owl-dot span {
  width: 30px;
  height: 6px;
  margin: 0 !important;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.46) !important;
}

.ndppc-home-banner .owl-theme .owl-dots .owl-dot.active span {
  background: #f7ebc2 !important;
}

.ndppc-home-intro-section {
  padding-top: 0;
}

.ndppc-home-intro-panel {
  padding: 0;
  overflow: hidden;
}

.ndppc-home-intro-copy {
  display: grid;
  gap: 1rem;
  align-content: start;
  padding: 1.85rem 2rem;
  background: #fff;
  border: 0;
  min-height: auto;
}

.ndppc-home-intro-copy .rounded-pill {
  background: var(--ndppc-accent-soft);
  color: #6c521f;
}

.ndppc-home-intro-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.9rem, 3vw, 2.8rem);
}

.ndppc-home-intro-copy .ndppc-banner-copy-stack {
  display: grid;
  gap: 0.95rem;
}

.ndppc-home-intro-copy .ndppc-banner-copy-stack p {
  margin: 0;
  max-width: none;
  color: var(--ndppc-copy-soft);
  font-size: 1rem;
  line-height: 1.72;
  text-align: justify;
}

.ndppc-home-intro-copy .banner-chip {
  margin-top: 0.1rem;
}

.ndppc-home-intro-copy .banner-chip .rounded-pill {
  background: #f5ecd7;
  border: 1px solid rgba(118, 89, 31, 0.08);
  color: #76591f;
}

.ndppc-home-intro-copy .banner_find {
  display: grid;
  gap: 1rem;
  margin-top: 0.2rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
}

.ndppc-home-intro-copy .banner_find p {
  margin: 0;
  color: var(--ndppc-copy-soft);
}

.ndppc-home-intro-copy .ndppc-action-row {
  gap: 0.75rem;
}

@media (max-width: 1199px) {
  .ndppc-home-intro-copy {
    padding: 1.55rem;
  }
}

@media (max-width: 991px) {
  .banner.ndppc-home-banner {
    padding-top: 0;
    padding-bottom: 6px;
  }

  .ndppc-home-banner .owl-theme .owl-nav {
    padding: 0 1rem;
  }

  .ndppc-home-banner .owl-theme .owl-nav [class*="owl-"] {
    width: 46px;
    height: 46px;
  }

  .ndppc-home-banner .ndppc-hero-slide img {
    height: 320px;
  }

  .ndppc-home-banner .ndppc-hero-slide figcaption {
    left: 1.25rem;
    top: auto;
    bottom: 1.25rem;
    transform: none;
    width: min(100%, calc(100% - 2rem));
    padding: 0;
  }

  .ndppc-home-banner .ndppc-hero-slide h3 {
    font-size: 2rem;
  }

  .ndppc-home-banner .ndppc-hero-slide p {
    font-size: 0.96rem;
  }

  .ndppc-home-banner .owl-theme .owl-dots {
    right: 1.25rem;
    bottom: 1.25rem;
    top: auto;
  }
}

@media (max-width: 767px) {
  .banner.ndppc-home-banner .banner_inner {
    padding: 0;
    border-radius: 0;
  }

  .ndppc-home-intro-copy {
    padding: 0.25rem;
  }

  .ndppc-home-banner .ndppc-hero-slide {
    min-height: 240px;
  }

  .ndppc-home-banner .ndppc-hero-slide img {
    height: 240px;
  }

  .ndppc-home-banner .ndppc-hero-slide figcaption {
    left: 0.85rem;
    right: 0.85rem;
    top: auto;
    bottom: 0.85rem;
    transform: none;
    width: auto;
    gap: 0.7rem;
    padding: 0;
    border-radius: 0;
  }

  .ndppc-home-banner .ndppc-banner-caption-top strong {
    font-size: 0.72rem;
  }

  .ndppc-home-banner .ndppc-banner-slide-index {
    min-width: 40px;
    height: 40px;
    font-size: 0.92rem;
  }

  .ndppc-home-banner .ndppc-hero-slide h3 {
    font-size: 1.45rem;
  }

  .ndppc-home-banner .ndppc-hero-slide p {
    font-size: 0.92rem;
    line-height: 1.56;
  }

  .ndppc-home-banner .owl-theme .owl-nav {
    padding: 0 0.65rem;
  }

  .ndppc-home-banner .owl-theme .owl-nav [class*="owl-"] {
    width: 40px;
    height: 40px;
  }

  .ndppc-home-banner .owl-theme .owl-dots {
    right: 0.85rem;
    bottom: 0.85rem;
    top: auto;
  }

  .ndppc-home-banner .owl-theme .owl-dots .owl-dot span {
    width: 20px;
  }

  .ndppc-home-banner .ndppc-banner-caption-actions .ndppc-link-btn {
    min-height: 40px;
    padding: 0.66rem 0.95rem;
  }

  .ndppc-home-intro-copy h1 {
    font-size: 1.65rem;
  }

  .ndppc-home-intro-copy .ndppc-banner-copy-stack p {
    font-size: 0.96rem;
    line-height: 1.64;
  }
}

/* Final Home Page Redesign */
.ndppc-home-overview-band {
  padding-top: 0;
  padding-bottom: 32px;
}

.ndppc-home-community-band {
  padding-top: 32px;
  padding-bottom: 32px;
}

.ndppc-home-dashboard-band {
  padding-top: 20px;
  padding-bottom: 36px;
}

.ndppc-home-network-band {
  padding-top: 15px;
  padding-bottom: 11px;
}

.ndppc-home-overview-layout,
.ndppc-home-community-layout {
  display: grid;
  gap: 1.5rem;
  align-items: start;
}

.ndppc-home-overview-layout {
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr);
  align-items: stretch;
}

.ndppc-home-overview-layout > .ndppc-panel {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.ndppc-home-community-layout {
  grid-template-columns: 1fr;
}

.ndppc-home-logo-head {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 0.5rem;
  text-align: center;
}

.ndppc-home-logo-head .rounded-pill {
  border: 1px solid rgba(181, 152, 89, 0.16);
  background: var(--ndppc-accent-soft);
  color: #6c521f;
}

.ndppc-home-logo-label {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 0.7rem 0.22rem;
}

.ndppc-home-logo-head h3 {
  margin: 0;
  color: #244a73;
  font-size: clamp(1.85rem, 2.9vw, 3rem);
  line-height: 1.06;
  letter-spacing: -0.03em;
}

.ndppc-home-logo-head p {
  margin: 0;
  max-width: 70ch;
  color: var(--ndppc-copy-soft);
  font-size: 0.96rem;
  line-height: 1.58;
}

.ndppc-home-logo-track {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  overflow: hidden;
  padding: 0.34rem 0.2rem 0.21rem;
  border: 1px solid transparent;
  background: transparent;
  border-radius: 10px;
}

.ndppc-home-logo-carousel {
  position: relative;
  width: 100%;
}

.ndppc-home-logo-carousel .owl-stage-outer {
  width: 100%;
  overflow: hidden;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 7%, #000 93%, transparent);
  mask-image: linear-gradient(to right, transparent, #000 7%, #000 93%, transparent);
}

.ndppc-home-logo-carousel .owl-stage {
  display: flex;
  align-items: center;
  transition-timing-function: linear !important;
}

.ndppc-home-logo-carousel .owl-item {
  display: flex;
  align-items: center;
}

.ndppc-home-logo-carousel .owl-item .item {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
}

.ndppc-home-logo-carousel .owl-nav,
.ndppc-home-logo-carousel .owl-dots {
  display: none !important;
}

.ndppc-home-logo-slide {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 74px;
  padding: 0;
  background: transparent;
}

.ndppc-home-logo-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 48px;
  padding: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
  transition: transform 0.22s ease;
}

.ndppc-home-logo-slide img {
  display: block;
  width: auto;
  max-width: 100%;
  max-height: 65px;
  object-fit: contain;
  background: transparent;
  opacity: 0.92;
  filter: saturate(0.94) contrast(1.02);
  transition: transform 0.2s ease, opacity 0.2s ease, filter 0.2s ease;
}

.ndppc-home-logo-carousel,
.ndppc-home-logo-carousel .owl-stage-outer,
.ndppc-home-logo-carousel .owl-stage,
.ndppc-home-logo-carousel .owl-item,
.ndppc-home-logo-carousel .owl-item .item,
.ndppc-home-logo-slide,
.ndppc-home-logo-mark,
.ndppc-home-logo-slide img {
  background-color: transparent !important;
}

.ndppc-home-logo-slide:hover .ndppc-home-logo-mark {
  transform: translateY(-2px);
}

.ndppc-home-logo-slide:hover img {
  opacity: 1;
  transform: scale(1.05);
  filter: saturate(1) contrast(1.03);
}

.ndppc-home-overview-copy,
.ndppc-home-quick-panel,
.ndppc-home-directory-panel,
.ndppc-home-announcement-panel,
.ndppc-home-updates-panel,
.ndppc-home-carousel-panel,
.ndppc-home-team-panel,
.ndppc-home-visit-panel {
  padding: 1.45rem;
}

.ndppc-home-overview-copy {
  display: grid;
  gap: 1rem;
  height: 100%;
}

.ndppc-home-directory-panel {
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100%;
}

.ndppc-home-announcement-panel {
  display: grid;
  grid-template-rows: auto 1fr;
  height: 100%;
}

.ndppc-home-updates-panel {
  display: grid;
  grid-template-rows: auto auto 1fr;
  gap: 1rem;
  height: 100%;
}

.ndppc-home-updates-heading {
  display: inline-flex;
  align-items: center;
  gap: 0.7rem;
  margin: 0;
}

.ndppc-home-updates-heading-icon {
  color: #215b3f;
  font-size: 1.9rem;
  line-height: 1;
}

.ndppc-home-overview-copy h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.48rem, 2.05vw, 1.95rem);
  line-height: 1.08;
}

.ndppc-home-overview-text {
  display: grid;
  gap: 0.95rem;
}

.ndppc-home-overview-text p {
  margin: 0;
  text-align: justify;
}

.ndppc-home-overview-pills {
  gap: 0.7rem;
}

.ndppc-home-overview-side,
.ndppc-home-network-stack {
  display: grid;
  gap: 1.25rem;
}

.ndppc-home-quick-grid,
.ndppc-home-person-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.ndppc-home-quick-card {
  display: grid;
  gap: 0.45rem;
  min-height: 118px;
  padding: 1rem;
  border-radius: 18px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: #f7f4ec;
  color: var(--ndppc-primary-dark);
  transition: transform 0.2s ease, border-color 0.2s ease;
}

.ndppc-home-quick-card:hover {
  transform: translateY(-2px);
  border-color: rgba(20, 53, 38, 0.16);
}

.ndppc-home-quick-card strong {
  font-size: 1rem;
}

.ndppc-home-quick-card small {
  color: var(--ndppc-copy-soft);
  font-size: 0.86rem;
  line-height: 1.5;
}

.ndppc-home-directory-panel .ndppc-home-directory-grid,
.ndppc-home-team-panel .ndppc-home-person-grid {
  margin-top: 1.1rem;
}

.ndppc-home-directory-panel .ndppc-home-directory-grid {
  height: 100%;
}

.ndppc-home-announcement-shell {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 1rem;
  height: 100%;
  margin-top: 1.1rem;
}

.ndppc-home-announcement-marquee {
  position: relative;
  min-height: 280px;
  max-height: 320px;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(245, 241, 232, 0.96) 100%);
}

.ndppc-home-announcement-marquee::before,
.ndppc-home-announcement-marquee::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 34px;
  z-index: 1;
  pointer-events: none;
}

.ndppc-home-announcement-marquee::before {
  top: 0;
  background: linear-gradient(180deg, rgba(247, 242, 233, 0.96), rgba(247, 242, 233, 0));
}

.ndppc-home-announcement-marquee::after {
  bottom: 0;
  background: linear-gradient(0deg, rgba(247, 242, 233, 0.96), rgba(247, 242, 233, 0));
}

.ndppc-home-announcement-track {
  display: grid;
  gap: 0.8rem;
  padding: 1rem;
  animation: ndppcHomeAnnouncementScroll 20s linear infinite;
}

.ndppc-home-announcement-marquee:hover .ndppc-home-announcement-track {
  animation-play-state: paused;
}

.ndppc-home-announcement-item {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 0.85rem;
  align-items: start;
  padding: 0.95rem 1rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(20, 53, 38, 0.08);
  color: var(--ndppc-primary-dark);
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.ndppc-home-announcement-item:hover {
  transform: translateX(3px);
  border-color: rgba(20, 53, 38, 0.16);
  background: rgba(255, 255, 255, 0.92);
}

.ndppc-home-announcement-item .material-symbols-outlined {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: rgba(33, 91, 63, 0.1);
  color: #215b3f;
  font-size: 1.05rem;
}

.ndppc-home-announcement-item span:last-child {
  font-weight: 700;
  line-height: 1.5;
}

@keyframes ndppcHomeAnnouncementScroll {
  0% { transform: translateY(0); }
  100% { transform: translateY(-50%); }
}

.ndppc-home-updates-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border: 1px solid rgba(20, 53, 38, 0.1);
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.78);
}

.ndppc-home-updates-tab {
  flex: 1 1 25%;
  min-width: 110px;
  padding: 0.88rem 0.9rem;
  border: 0;
  border-right: 1px solid rgba(20, 53, 38, 0.1);
  background: transparent;
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  font-weight: 800;
  line-height: 1.2;
  transition: background 0.2s ease, color 0.2s ease;
}

.ndppc-home-updates-tab:last-child {
  border-right: 0;
}

.ndppc-home-updates-tab.active {
  background: linear-gradient(180deg, rgba(234, 244, 238, 0.96), rgba(224, 238, 230, 0.96));
  color: #215b3f;
}

.ndppc-home-updates-tab:hover {
  background: rgba(247, 242, 233, 0.8);
}

.ndppc-home-updates-panels {
  display: grid;
  height: 100%;
  min-height: 0;
}

.ndppc-home-updates-pane {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 1rem;
  height: 100%;
  min-height: 0;
}

.ndppc-home-updates-list {
  display: grid;
  height: 100%;
  gap: 0.8rem;
  align-content: start;
  min-height: 0;
}

.ndppc-home-update-item {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr);
  gap: 0.85rem;
  align-items: start;
  padding: 0 0 0.95rem;
  border-bottom: 1px solid rgba(20, 53, 38, 0.08);
  color: var(--ndppc-primary-dark);
  transition: transform 0.2s ease, color 0.2s ease;
}

.ndppc-home-update-item:hover {
  transform: translateX(3px);
  color: var(--ndppc-primary);
}

.ndppc-home-update-item:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.ndppc-home-update-item .material-symbols-outlined {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 12px;
  background: rgba(33, 91, 63, 0.08);
  color: #215b3f;
  font-size: 1.08rem;
}

.ndppc-home-update-item-copy {
  display: grid;
  gap: 0.18rem;
}

.ndppc-home-update-item-copy strong {
  font-size: 0.98rem;
  line-height: 1.45;
  text-align: justify;
}

.ndppc-home-update-item-copy small {
  color: var(--ndppc-copy-soft);
  font-size: 0.84rem;
  line-height: 1.45;
  text-align: justify;
}

.ndppc-home-updates-footer {
  display: flex;
  justify-content: flex-end;
}

.ndppc-home-team-panel {
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.ndppc-home-dashboard-head {
  display: grid;
  justify-items: center;
  gap: 0.5rem;
  margin-bottom: 1.35rem;
  text-align: center;
}

.ndppc-home-dashboard-head .rounded-pill {
  border: 1px solid rgba(181, 152, 89, 0.16);
  background: var(--ndppc-accent-soft);
  color: #6c521f;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.ndppc-home-dashboard-head h3 {
  margin: 0;
  color: #143526;
  font-size: clamp(1.95rem, 3vw, 2.7rem);
  line-height: 1.05;
}

.ndppc-home-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1.2rem;
  align-items: stretch;
}

.ndppc-home-dashboard-card {
  position: relative;
  display: grid;
  grid-template-rows: auto 1fr;
  align-content: center;
  justify-items: center;
  gap: 1rem;
  min-height: 236px;
  padding: 1.3rem 1.1rem 1.2rem;
  border-radius: 28px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 244, 238, 0.97)),
    radial-gradient(circle at top right, var(--ndppc-dashboard-glow, rgba(33, 91, 63, 0.18)), transparent 68%);
  box-shadow: 0 18px 36px rgba(22, 41, 31, 0.06);
  text-decoration: none;
  color: inherit;
  text-align: center;
  overflow: hidden;
  isolation: isolate;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.ndppc-home-dashboard-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 5px;
  background: linear-gradient(90deg, var(--ndppc-dashboard-accent, #215b3f), rgba(255, 255, 255, 0));
  z-index: 0;
}

.ndppc-home-dashboard-card::after {
  content: "";
  position: absolute;
  width: 128px;
  height: 128px;
  top: -34px;
  right: -28px;
  border-radius: 50%;
  background: radial-gradient(circle, var(--ndppc-dashboard-glow, rgba(33, 91, 63, 0.18)) 0%, rgba(255, 255, 255, 0) 72%);
  z-index: 0;
}

.ndppc-home-dashboard-card > * {
  position: relative;
  z-index: 1;
}

.ndppc-home-dashboard-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 44px rgba(22, 41, 31, 0.11);
  border-color: rgba(24, 76, 56, 0.14);
}

.ndppc-home-dashboard-icon {
  display: grid;
  place-items: center;
  width: 94px;
  height: 94px;
  border-radius: 26px;
  background: linear-gradient(180deg, var(--ndppc-dashboard-soft, #e7f3ed) 0%, rgba(255, 255, 255, 0.96) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.84);
}

.ndppc-home-dashboard-icon .material-symbols-outlined {
  color: var(--ndppc-dashboard-accent, #215b3f);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: 3.65rem !important;
  line-height: 1;
  font-variation-settings: "FILL" 0, "wght" 300, "GRAD" 0, "opsz" 48;
}

.ndppc-home-dashboard-copy {
  display: grid;
  gap: 0.34rem;
  align-content: center;
  justify-items: center;
  text-align: center;
}

.ndppc-home-dashboard-kicker {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.24rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.86);
  color: var(--ndppc-dashboard-accent, #215b3f);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.ndppc-home-dashboard-card .ndppc-count {
  font-size: clamp(2.85rem, 3vw, 3.65rem);
  color: var(--ndppc-dashboard-accent, #1b56b0);
  letter-spacing: -0.04em;
  text-shadow: 0 8px 20px var(--ndppc-dashboard-glow, rgba(33, 91, 63, 0.16));
}

.ndppc-home-dashboard-card strong {
  color: #0f1823;
  font-size: 1.08rem;
  line-height: 1.28;
  font-weight: 700;
  max-width: 11ch;
}

.ndppc-home-dashboard-card span:last-child {
  color: var(--ndppc-copy-soft);
  font-size: 0.92rem;
  line-height: 1.45;
  font-weight: 500;
}

.ndppc-home-team-layout {
  display: grid;
  grid-template-columns: minmax(360px, 1.02fr) minmax(320px, 0.98fr);
  gap: 1.5rem;
  align-items: stretch;
}

.ndppc-home-team-stage,
.ndppc-home-team-roster-wrap {
  display: grid;
  gap: 1rem;
  align-content: start;
  height: 100%;
}

.ndppc-home-team-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

.ndppc-home-team-summary-card {
  display: grid;
  gap: 0.18rem;
  padding: 0.9rem 1rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(20, 53, 38, 0.08);
}

.ndppc-home-team-summary-card strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.5rem;
  line-height: 1;
}

.ndppc-home-team-summary-card span {
  color: var(--ndppc-copy-soft);
  font-size: 0.88rem;
  font-weight: 700;
}

.ndppc-home-team-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  margin-top: 0.35rem;
  flex-wrap: wrap;
}

.ndppc-home-team-bar span {
  color: var(--ndppc-primary-dark);
  font-weight: 700;
}

.ndppc-home-team-bar .ndppc-link-btn {
  min-height: 38px;
  padding: 0.52rem 0.88rem;
  border-radius: 10px;
  font-size: 0.9rem;
  white-space: nowrap;
  flex: 0 0 auto;
}

.ndppc-home-team-lead {
  display: grid;
  grid-template-columns: minmax(220px, 0.82fr) minmax(0, 1.18fr);
  gap: 0;
  overflow: hidden;
  border-radius: 28px;
  background: #fff;
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 22px 42px rgba(22, 41, 31, 0.08);
}

.ndppc-home-team-lead-media img {
  width: 100%;
  height: 100%;
  min-height: 330px;
  object-fit: cover;
}

.ndppc-home-team-lead-copy {
  display: grid;
  gap: 0.8rem;
  align-content: center;
  padding: 1.5rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 237, 222, 0.94));
}

.ndppc-home-team-lead-top {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.ndppc-home-team-tag {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.42rem 0.75rem;
  border-radius: 999px;
  background: rgba(25, 67, 50, 0.08);
  color: var(--ndppc-primary-dark);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.ndppc-home-team-lead-copy h4,
.ndppc-home-team-mini-copy h4 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.22rem;
}

.ndppc-home-team-lead-copy p,
.ndppc-home-team-mini-copy p {
  margin: 0;
  color: var(--ndppc-copy-soft);
  line-height: 1.6;
}

.ndppc-home-team-roster {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  height: 100%;
}

@media (min-width: 992px) {
  .ndppc-home-team-roster {
    grid-auto-rows: max-content;
    align-content: space-between;
  }
}

.ndppc-home-team-mini {
  display: grid;
  grid-template-columns: 126px minmax(0, 1fr);
  gap: 0.85rem;
  align-items: stretch;
  padding: 0.85rem;
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 237, 222, 0.94));
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 12px 22px rgba(22, 41, 31, 0.05);
}

.ndppc-home-team-mini-media {
  display: flex;
}

.ndppc-home-team-mini-media img {
  width: 100%;
  height: 100%;
  min-height: 0;
  object-fit: cover;
  border-radius: 18px;
}

.ndppc-home-team-mini-copy {
  display: grid;
  gap: 0.55rem;
}

.ndppc-home-team-mini-copy .ndppc-card-actions,
.ndppc-home-team-lead-copy .ndppc-card-actions {
  margin-top: 0.2rem;
}

.ndppc-home-visit-panel iframe {
  display: block;
  width: 100%;
  min-height: 340px;
  margin-top: 1.25rem;
  border: 0;
  border-radius: 18px;
}

.ndppc-home-access-list {
  list-style: none;
  margin: 1rem 0 0;
  padding: 0;
  display: grid;
  gap: 0.9rem;
}

.ndppc-home-access-list li {
  display: grid;
  gap: 0.25rem;
}

.ndppc-home-access-list strong {
  color: var(--ndppc-primary-dark);
}

@media (max-width: 1199px) {
  .ndppc-home-overview-layout,
  .ndppc-home-community-layout {
    grid-template-columns: 1fr;
  }

  .ndppc-home-updates-scroll {
    min-height: 220px;
    max-height: 250px;
  }

  .ndppc-home-announcement-marquee {
    min-height: 220px;
    max-height: 260px;
  }

  .ndppc-home-dashboard-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .ndppc-home-team-layout {
    grid-template-columns: 1fr;
  }

  .ndppc-home-team-summary {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .ndppc-home-logo-slide {
    min-height: 96px;
  }

  .ndppc-home-logo-mark {
    min-height: 66px;
  }

  .ndppc-home-logo-slide img {
    max-height: 60px;
  }
}

@media (max-width: 991px) {
  .ndppc-home-quick-grid,
  .ndppc-home-person-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ndppc-home-dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ndppc-home-logo-head h3 {
    font-size: 2rem;
  }

  .ndppc-home-logo-head p {
    font-size: 0.95rem;
  }

  .ndppc-home-logo-track {
    padding: 0.52rem 0.1rem;
  }

  .ndppc-home-logo-slide {
    min-height: 74px;
  }

  .ndppc-home-logo-mark {
    min-height: 48px;
  }

  .ndppc-home-logo-slide img {
    max-height: 67px;
  }

  .ndppc-home-dashboard-icon {
    width: 82px;
    height: 82px;
  }

  .ndppc-home-dashboard-icon .material-symbols-outlined {
    font-size: 3.2rem !important;
  }

  .ndppc-home-team-summary {
    grid-template-columns: 1fr;
  }

  .ndppc-home-team-lead {
    grid-template-columns: 1fr;
  }

  .ndppc-home-team-lead-media img {
    min-height: 260px;
  }
}

@media (max-width: 767px) {
  .ndppc-home-overview-copy,
  .ndppc-home-quick-panel,
  .ndppc-home-directory-panel,
  .ndppc-home-announcement-panel,
  .ndppc-home-updates-panel,
  .ndppc-home-carousel-panel,
  .ndppc-home-team-panel {
    padding: 1.15rem;
  }

  .ndppc-home-updates-tabs {
    border-radius: 16px;
  }

  .ndppc-home-updates-tab {
    flex: 1 1 50%;
    min-width: 0;
    font-size: 0.95rem;
    padding: 0.8rem 0.7rem;
  }

  .ndppc-home-update-item {
    grid-template-columns: 30px minmax(0, 1fr);
    gap: 0.7rem;
    padding: 0 0 0.85rem;
  }

  .ndppc-home-update-item .material-symbols-outlined {
    width: 30px;
    height: 30px;
    border-radius: 10px;
  }

  .ndppc-home-updates-heading {
    gap: 0.5rem;
  }

  .ndppc-home-updates-heading-icon {
    font-size: 1.55rem;
  }

  .ndppc-home-update-item-copy strong {
    font-size: 0.92rem;
  }

  .ndppc-home-announcement-marquee {
    min-height: 200px;
    max-height: 220px;
  }

  .ndppc-home-announcement-track {
    padding: 0.85rem;
  }

  .ndppc-home-announcement-item {
    grid-template-columns: 30px minmax(0, 1fr);
    gap: 0.7rem;
    padding: 0.85rem 0.9rem;
  }

  .ndppc-home-announcement-item .material-symbols-outlined {
    width: 30px;
    height: 30px;
    border-radius: 10px;
  }

  .ndppc-home-overview-copy h2 {
    font-size: 1.72rem;
  }

  .ndppc-home-logo-head h3 {
    font-size: 1.58rem;
  }

  .ndppc-home-logo-head p {
    font-size: 0.9rem;
    line-height: 1.55;
  }

  .ndppc-home-logo-carousel .owl-stage-outer {
    -webkit-mask-image: none;
    mask-image: none;
  }

  .ndppc-home-logo-track {
    padding: 0.22rem 0 0.14rem;
    border-radius: 10px;
  }

  .ndppc-home-logo-label {
    padding: 0 0.5rem 0.12rem;
  }

  .ndppc-home-logo-slide {
    min-height: 56px;
    padding: 0;
  }

  .ndppc-home-logo-mark {
    min-height: 38px;
  }

  .ndppc-home-logo-slide img {
    max-height: 41px;
  }

  .ndppc-home-dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.8rem;
  }

  .ndppc-home-dashboard-icon {
    width: 60px;
    height: 60px;
    border-radius: 18px;
  }

  .ndppc-home-dashboard-icon .material-symbols-outlined {
    font-size: 2.4rem !important;
  }

  .ndppc-home-dashboard-card {
    min-height: 164px;
    padding: 0.85rem 0.7rem;
    border-radius: 22px;
  }

  .ndppc-home-dashboard-copy {
    gap: 0.28rem;
  }

  .ndppc-home-dashboard-card .ndppc-count {
    font-size: 2.3rem;
  }

  .ndppc-home-dashboard-card strong {
    font-size: 0.86rem;
    line-height: 1.22;
    max-width: 9ch;
  }

  .ndppc-home-dashboard-kicker {
    font-size: 0.56rem;
    letter-spacing: 0.1em;
    padding: 0.18rem 0.5rem;
  }

  .ndppc-home-quick-grid,
  .ndppc-home-person-grid {
    grid-template-columns: 1fr;
  }

  .ndppc-home-team-mini {
    grid-template-columns: 112px minmax(0, 1fr);
    gap: 0.85rem;
    padding: 0.75rem;
  }

  .ndppc-home-team-mini-media {
    min-width: 112px;
  }

  .ndppc-home-team-mini-media img {
    width: 112px;
    height: 132px;
    min-height: 132px;
    border-radius: 14px;
  }

  .ndppc-home-team-lead-media {
    background: rgba(244, 237, 222, 0.94);
  }

  .ndppc-home-team-lead-media img {
    display: block;
    height: auto;
    min-height: 0;
    object-fit: contain;
    object-position: center top;
  }

  .ndppc-home-visit-panel iframe {
    min-height: 260px;
  }
}

/* DIC-inspired Home Carousel Item Override */
.ndppc-home-banner .ndppc-home-carousel {
  position: relative;
  display: block;
  width: 100%;
  min-height: clamp(400px, 40vw, 575px);
  overflow: hidden;
  isolation: isolate;
}

.ndppc-home-banner .ndppc-home-carousel .carousel-inner {
  position: relative;
  display: block;
  width: 100%;
  min-height: clamp(400px, 40vw, 575px);
  overflow: hidden;
}

.ndppc-home-banner .ndppc-home-carousel .carousel-item {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  min-height: clamp(400px, 40vw, 575px);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.6s ease;
}

.ndppc-home-banner .ndppc-home-carousel .carousel-item.active,
.ndppc-home-banner .ndppc-home-carousel .carousel-item.carousel-item-start,
.ndppc-home-banner .ndppc-home-carousel .carousel-item.carousel-item-end {
  position: relative;
  opacity: 1;
  visibility: visible;
  z-index: 1;
}

.ndppc-home-banner .ndppc-home-carousel .carousel-item .ndppc-hero-slide {
  width: 100%;
  min-height: clamp(400px, 40vw, 575px);
}

.ndppc-home-banner .ndppc-home-carousel-indicators {
  position: absolute;
  right: 1.8rem;
  bottom: 1.8rem;
  left: auto;
  z-index: 3;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  margin: 0;
}

.ndppc-home-banner .ndppc-home-carousel-indicators [data-bs-target] {
  width: 30px;
  height: 6px;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.46);
  opacity: 1;
}

.ndppc-home-banner .ndppc-home-carousel-indicators .active {
  background: #f7ebc2;
}

.ndppc-home-banner .ndppc-home-carousel-control {
  position: absolute;
  top: 50%;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  margin-top: 0;
  transform: translateY(-50%);
  border: 1px solid rgba(20, 53, 38, 0.12);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.92);
  color: var(--ndppc-primary-dark);
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.1);
  opacity: 1;
}

.ndppc-home-banner .carousel-control-prev.ndppc-home-carousel-control {
  left: 1.6rem;
}

.ndppc-home-banner .carousel-control-next.ndppc-home-carousel-control {
  right: 1.6rem;
}

.ndppc-home-banner .ndppc-home-carousel-control:hover {
  background: #fff;
  color: var(--ndppc-primary-dark);
}

.ndppc-home-banner .ndppc-home-carousel-control .material-symbols-outlined {
  font-size: 1.7rem;
  line-height: 1;
}

@media (max-width: 991px) {
  .ndppc-home-banner .ndppc-home-carousel,
  .ndppc-home-banner .ndppc-home-carousel .carousel-inner,
  .ndppc-home-banner .ndppc-home-carousel .carousel-item,
  .ndppc-home-banner .ndppc-home-carousel .carousel-item .ndppc-hero-slide {
    min-height: 320px;
  }

  .ndppc-home-banner .carousel-control-prev.ndppc-home-carousel-control {
    left: 1rem;
  }

  .ndppc-home-banner .carousel-control-next.ndppc-home-carousel-control {
    right: 1rem;
  }

  .ndppc-home-banner .ndppc-home-carousel-control {
    width: 46px;
    height: 46px;
  }

  .ndppc-home-banner .ndppc-home-carousel-indicators {
    right: 1.25rem;
    bottom: 1.25rem;
  }
}

@media (max-width: 767px) {
  .ndppc-home-banner .ndppc-home-carousel,
  .ndppc-home-banner .ndppc-home-carousel .carousel-inner,
  .ndppc-home-banner .ndppc-home-carousel .carousel-item,
  .ndppc-home-banner .ndppc-home-carousel .carousel-item .ndppc-hero-slide {
    min-height: 240px;
  }

  .ndppc-home-banner .ndppc-home-carousel-control {
    width: 40px;
    height: 40px;
  }

  .ndppc-home-banner .carousel-control-prev.ndppc-home-carousel-control {
    left: 0.65rem;
  }

  .ndppc-home-banner .carousel-control-next.ndppc-home-carousel-control {
    right: 0.65rem;
  }

  .ndppc-home-banner .ndppc-home-carousel-indicators {
    right: 0.85rem;
    bottom: 0.85rem;
  }

  .ndppc-home-banner .ndppc-home-carousel-indicators [data-bs-target] {
    width: 20px;
  }
}

/* Final Home Alert Strip Refresh */
.ndppc-alert-strip.ndppc-alert-strip-template {
  position: relative;
  background: transparent;
  border-top: 1px solid transparent;
  border-bottom: 1px solid transparent;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-strip-inner {
  position: relative;
  gap: 1.15rem;
  min-height: 68px;
  padding: 0.9rem 0;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-strip-inner::before {
  content: none;
}

.ndppc-alert-strip.ndppc-alert-strip-template strong,
.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-marquee,
.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-outline-btn {
  position: relative;
  z-index: 1;
}

.ndppc-alert-strip.ndppc-alert-strip-template strong {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.6rem;
  min-height: 40px;
  padding: 0.62rem 1.2rem 0.62rem 0.96rem;
  border-radius: 0;
  clip-path: polygon(0 0, calc(100% - 18px) 0, 100% 50%, calc(100% - 18px) 100%, 0 100%, 12px 50%);
  background: linear-gradient(135deg, #173b2d 0%, #295742 100%);
  border: 1px solid rgba(23, 59, 45, 0.26);
  color: #fff;
  font-size: 0.79rem;
  letter-spacing: 0.08em;
  box-shadow: 0 14px 24px rgba(23, 59, 45, 0.22);
}

.ndppc-alert-strip.ndppc-alert-strip-template strong::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #d2a63a;
  box-shadow: 0 0 0 6px rgba(210, 166, 58, 0.18);
  animation: ndppc-alert-pulse 1.8s ease-in-out infinite;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-marquee {
  min-width: 0;
  padding: 0.75rem 0.95rem;
  border-radius: 16px;
  background: transparent;
  border: 1px solid transparent;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-marquee:hover .ndppc-alert-marquee-track {
  animation-play-state: paused;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-marquee-track {
  gap: 2.75rem;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-marquee-track a {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  color: #143526;
  font-weight: 700;
  text-decoration: none;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-marquee-track a::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #c89c33;
  flex: 0 0 auto;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-marquee-track a:hover {
  color: #8a6113;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-outline-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  min-height: 40px;
  padding: 0.64rem 1.16rem;
  border-radius: 12px;
  clip-path: none;
  border-color: rgba(25, 67, 50, 0.18);
  background: #e0ebe4;
  color: #143526;
  box-shadow: none;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-outline-btn::after {
  content: "east";
  font-family: "Material Symbols Outlined";
  font-size: 1rem;
  line-height: 1;
}

.ndppc-alert-strip.ndppc-alert-strip-template .ndppc-outline-btn:hover {
  background: #d3e3d8;
  border-color: rgba(25, 67, 50, 0.28);
  color: #0f2a1f;
}

@keyframes ndppc-alert-pulse {
  0%,
  100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(210, 166, 58, 0.22);
  }

  50% {
    transform: scale(1.08);
    box-shadow: 0 0 0 6px rgba(210, 166, 58, 0.08);
  }
}

@media (max-width: 991px) {
  .ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-strip-inner::before {
    inset: 8px 0;
  }

  .ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-marquee {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-strip-inner {
    gap: 0.8rem;
  }

  .ndppc-alert-strip.ndppc-alert-strip-template strong {
    justify-self: center;
  }

  .ndppc-alert-strip.ndppc-alert-strip-template .ndppc-alert-marquee {
    padding: 0.7rem 0.85rem;
  }

  .ndppc-alert-strip.ndppc-alert-strip-template .ndppc-outline-btn {
    justify-self: center;
  }
}

/* Final Institutional Footer Redesign */
.ndppc-footer {
  position: relative;
  padding: 72px 0 50px;
  overflow: hidden;
  background: #0f2b1e;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ndppc-footer::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 8px;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.16), rgba(189, 152, 75, 0.34), rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0));
}

.ndppc-footer .container,
.ndppc-subfooter .container {
  position: relative;
}

.ndppc-footer-inner {
  position: relative;
  gap: 1.3rem;
  padding: 1.35rem;
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.38);
  border: 1px solid rgba(255, 255, 255, 0.65);
  box-shadow: 0 26px 54px rgba(18, 44, 34, 0.1);
  backdrop-filter: blur(10px);
}

.ndppc-footer-col {
  position: relative;
  padding: 1.2rem 1.15rem 1.2rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}

.ndppc-footer-col::before {
  content: "";
  position: absolute;
  top: 0;
  left: 1.15rem;
  right: 1.15rem;
  height: 4px;
  border-radius: 0 0 999px 999px;
  background: linear-gradient(90deg, rgba(22, 61, 46, 0.88), rgba(189, 152, 75, 0.68));
}

.ndppc-footer-col:first-child {
  background: linear-gradient(180deg, #173a2f 0%, #204536 100%);
  border-color: rgba(255, 255, 255, 0.09);
  box-shadow: 0 18px 38px rgba(24, 60, 48, 0.16);
}

.ndppc-footer-col:first-child::before {
  background: linear-gradient(90deg, rgba(249, 233, 190, 0.95), rgba(213, 181, 104, 0.8));
}

.ndppc-footer-col:first-child strong,
.ndppc-footer-col:first-child p,
.ndppc-footer-col:first-child a {
  color: rgba(255, 255, 255, 0.94);
}

.ndppc-footer-col:first-child p strong {
  color: #f2db9b;
}

.ndppc-footer-brand {
  margin-bottom: 1.15rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.ndppc-footer-brand img {
  width: 78px;
  height: 78px;
  padding: 0.75rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.96);
  border-color: rgba(255, 255, 255, 0.18);
  box-shadow: 0 10px 22px rgba(10, 26, 19, 0.18);
}

.ndppc-footer-brand strong {
  margin-bottom: 0.35rem;
  font-size: 1.18rem;
  line-height: 1.24;
}

.ndppc-footer-col h3 {
  margin: 0 0 1rem;
  color: #7a5a21;
  font-size: 0.96rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ndppc-footer-col:first-child h3 {
  color: rgba(250, 236, 199, 0.94);
}

.ndppc-footer-col ul {
  display: grid;
  gap: 0.62rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ndppc-footer-col li + li {
  margin-top: 0;
}

.ndppc-footer-col:nth-child(2) a,
.ndppc-footer-col:nth-child(3) a {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.72rem 0.85rem;
  border-radius: 15px;
  background: linear-gradient(180deg, rgba(248, 244, 236, 0.95), rgba(243, 237, 225, 0.95));
  border: 1px solid rgba(20, 53, 38, 0.08);
  color: var(--ndppc-primary-dark);
  font-weight: 600;
  line-height: 1.35;
  transition: transform 0.2s ease, border-color 0.2s ease, background 0.2s ease;
}

.ndppc-footer-col:nth-child(2) a::before,
.ndppc-footer-col:nth-child(3) a::before {
  content: "\2192";
  flex: 0 0 auto;
  color: #9b7932;
  font-size: 0.95rem;
}

.ndppc-footer-col:nth-child(2) a:hover,
.ndppc-footer-col:nth-child(3) a:hover {
  transform: translateY(-2px);
  border-color: rgba(20, 53, 38, 0.16);
  background: linear-gradient(180deg, rgba(250, 247, 241, 1), rgba(246, 240, 230, 1));
}

.ndppc-footer-col:last-child {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(248, 243, 234, 0.94));
}

.ndppc-footer-map {
  min-height: 280px;
  border: 1px solid rgba(20, 53, 38, 0.09);
  border-radius: 18px;
  box-shadow: 0 16px 34px rgba(18, 44, 34, 0.1);
  background: #fff;
}

.btn-last-update {
  margin-top: auto;
  align-self: flex-start;
  padding: 0.62rem 0.95rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.16);
  color: #fff;
  box-shadow: none;
}

.btn-last-update:hover {
  background: rgba(255, 255, 255, 0.2);
  color: #fff;
}

.ndppc-subfooter {
  padding: 1rem 0 1.1rem;
  background: linear-gradient(90deg, #123126 0%, #173c2f 52%, #123126 100%);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ndppc-subfooter ul {
  gap: 0.7rem;
}

.ndppc-subfooter ul a {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0.2rem 0.7rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  transition: background 0.2s ease;
}

.ndppc-subfooter ul a:hover {
  background: rgba(255, 255, 255, 0.13);
}

@media (max-width: 1199px) {
  .ndppc-footer {
    padding: 64px 0 46px;
  }

  .ndppc-footer-inner {
    grid-template-columns: minmax(240px, 1fr) repeat(2, minmax(0, 1fr));
  }

  .ndppc-footer-col:first-child,
  .ndppc-footer-col:last-child {
    grid-column: 1 / -1;
  }

  .ndppc-footer-map {
    min-height: 260px;
  }
}

@media (max-width: 767px) {
  .ndppc-footer {
    padding: 56px 0 40px;
  }

  .ndppc-footer-inner {
    gap: 1rem;
    padding: 1rem;
    border-radius: 24px;
  }

  .ndppc-footer-col {
    padding: 1rem;
    border-radius: 20px;
  }

  .ndppc-footer-col::before {
    left: 1rem;
    right: 1rem;
  }

  .ndppc-footer-brand {
    margin-bottom: 1rem;
    padding-bottom: 0.85rem;
  }

  .ndppc-footer-brand img {
    width: 70px;
    height: 70px;
  }

  .ndppc-footer-map {
    min-height: 230px;
    border-radius: 16px;
  }

  .btn-last-update {
    width: 100%;
    justify-content: center;
  }
}

/* Final Flat Footer Override */
.ndppc-footer {
  position: relative;
  padding: 68px 0 44px;
  background: linear-gradient(180deg, #17362b 0%, #10261f 100%);
  border-top: 4px solid #c6a45f;
  overflow: hidden;
}

.ndppc-footer::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.03), transparent 18%, transparent 82%, rgba(255, 255, 255, 0.03)),
    linear-gradient(180deg, rgba(255, 255, 255, 0.035), transparent 34%);
  pointer-events: none;
}

.ndppc-footer .container,
.ndppc-subfooter .container {
  position: relative;
  z-index: 1;
}

.ndppc-footer-inner {
  gap: 2rem;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.ndppc-footer-col {
  padding: 0 0 0 1.55rem;
  background: transparent;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

.ndppc-footer-col::before {
  display: none;
}

.ndppc-footer-col:first-child {
  padding-left: 0;
}

.ndppc-footer-col + .ndppc-footer-col {
  border-left: 1px solid rgba(255, 255, 255, 0.12);
}

.ndppc-footer-brand {
  margin-bottom: 1.15rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.ndppc-footer-brand img {
  width: 76px;
  height: 76px;
  padding: 0.55rem;
  border-radius: 0;
  background: #fff;
  border: 0;
  box-shadow: none;
}

.ndppc-footer-brand strong {
  margin-bottom: 0.35rem;
  font-size: 1.18rem;
  line-height: 1.24;
  color: #ffffff;
}

.ndppc-footer-col h3 {
  margin: 0 0 1rem;
  color: #e7cb8e;
  font-size: 0.9rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.ndppc-footer-col p,
.ndppc-footer-col a,
.ndppc-footer-col li {
  color: rgba(255, 255, 255, 0.84);
}

.ndppc-footer-col p {
  margin-bottom: 0.75rem;
}

.ndppc-footer-col p strong {
  color: #eedba8;
}

.ndppc-footer-col ul {
  display: grid;
  gap: 0.7rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ndppc-footer-col li + li {
  margin-top: 0;
}

.ndppc-footer-col:nth-child(2) a,
.ndppc-footer-col:nth-child(3) a {
  display: inline-flex;
  align-items: baseline;
  gap: 0.5rem;
  padding: 0;
  background: transparent;
  border: 0;
  border-radius: 0;
  color: rgba(255, 255, 255, 0.84);
  font-weight: 500;
  line-height: 1.45;
  text-decoration: none;
  transition: color 0.2s ease, transform 0.2s ease;
}

.ndppc-footer-col:nth-child(2) a::before,
.ndppc-footer-col:nth-child(3) a::before {
  content: "\203A";
  flex: 0 0 auto;
  color: #c6a45f;
  font-size: 1rem;
}

.ndppc-footer-col:nth-child(2) a:hover,
.ndppc-footer-col:nth-child(3) a:hover {
  color: #ffffff;
  transform: translateX(2px);
}

.ndppc-footer-map {
  min-height: 270px;
  margin-top: 0.15rem;
  border: 1px solid rgba(231, 203, 142, 0.24);
  border-radius: 0;
  box-shadow: none;
  background: #f4efe4;
}

.btn-last-update {
  margin-top: auto;
  align-self: flex-start;
  padding: 0.62rem 0.9rem;
  border-radius: 0 !important;
  border: 1px solid rgba(231, 203, 142, 0.32);
  background: transparent;
  color: #eedba8;
  font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow: none;
}

.btn-last-update:hover {
  background: rgba(231, 203, 142, 0.08);
  color: #fff2ca;
}

.ndppc-subfooter {
  padding: 0.95rem 0 1.05rem;
  background: #0b1d18;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.ndppc-subfooter .copyright,
.ndppc-subfooter a {
  color: rgba(255, 255, 255, 0.82);
}

.ndppc-subfooter ul {
  gap: 1rem;
}

.ndppc-subfooter ul a {
  padding: 0;
  min-height: auto;
  background: transparent;
  border-radius: 0;
}

.ndppc-subfooter ul a:hover {
  background: transparent;
  color: #ffffff;
  text-decoration: underline;
}

@media (max-width: 1199px) {
  .ndppc-footer {
    padding: 60px 0 44px;
  }

  .ndppc-footer-inner {
    gap: 1.6rem;
  }

  .ndppc-footer-col {
    padding-left: 1.2rem;
  }

  .ndppc-footer-col:last-child {
    padding-left: 0;
    padding-top: 1.2rem;
    border-left: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ndppc-footer-map {
    min-height: 250px;
  }
}

@media (max-width: 767px) {
  .ndppc-footer {
    padding: 52px 0 38px;
  }

  .ndppc-footer-inner {
    gap: 1.15rem;
  }

  .ndppc-footer-col {
    padding: 1rem 0 0;
    border-left: 0;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
  }

  .ndppc-footer-col:first-child {
    padding-top: 0;
    border-top: 0;
  }

  .ndppc-footer-brand {
    margin-bottom: 1rem;
    padding-bottom: 0.9rem;
  }

  .ndppc-footer-brand img {
    width: 68px;
    height: 68px;
  }

  .ndppc-footer-map {
    min-height: 220px;
  }

  .btn-last-update {
    width: 100%;
    justify-content: center;
  }
}

/* Final Compact Color Footer Override */
.ndppc-footer {
  padding: 38px 0 22px;
  background: linear-gradient(90deg, #143126 0%, #18382c 52%, #1d3f31 100%);
  border-top: 3px solid #c6a45f;
}

.ndppc-footer::before {
  display: none;
}

.ndppc-footer-inner {
  grid-template-columns: minmax(230px, 1.08fr) minmax(155px, 0.8fr) minmax(170px, 0.86fr) minmax(285px, 1fr);
  gap: 0;
  align-items: stretch;
}

.ndppc-footer-col {
  padding: 0.85rem 1rem 0.9rem;
}

.ndppc-footer-col:first-child {
  background: #15382c;
}

.ndppc-footer-col:nth-child(2) {
  background: #1a4032;
}

.ndppc-footer-col:nth-child(3) {
  background: #204736;
}

.ndppc-footer-col:last-child {
  background: #e4d4ac;
}

.ndppc-footer-col + .ndppc-footer-col {
  border-left: 1px solid rgba(255, 255, 255, 0.1);
}

.ndppc-footer-col:last-child {
  border-left-color: rgba(20, 53, 38, 0.14);
}

.ndppc-footer-brand {
  margin-bottom: 0.8rem;
  padding-bottom: 0.7rem;
}

.ndppc-footer-brand img {
  width: 58px;
  height: 58px;
  padding: 0.42rem;
}

.ndppc-footer-brand strong {
  font-size: 1.04rem;
}

.ndppc-footer-kicker {
  margin: 0 0 0.28rem !important;
  color: #eedba8 !important;
  font-size: 0.72rem !important;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.ndppc-footer-col h3 {
  margin: 0 0 0.72rem;
  font-size: 0.82rem;
  letter-spacing: 0.14em;
}

.ndppc-footer-col p,
.ndppc-footer-col a,
.ndppc-footer-col li {
  font-size: 0.92rem;
  line-height: 1.38;
}

.ndppc-footer-col p {
  margin-bottom: 0.45rem;
}

.ndppc-footer-col ul {
  gap: 0.42rem;
}

.ndppc-footer-col:nth-child(2) a,
.ndppc-footer-col:nth-child(3) a {
  font-size: 0.9rem;
}

.ndppc-footer-map {
  min-height: 180px;
  margin-top: 0.05rem;
}

.btn-last-update {
  margin-top: 0.7rem;
  padding: 0.46rem 0.72rem;
  font-size: 0.78rem;
}

.ndppc-subfooter {
  padding: 0.65rem 0 0.75rem;
}

.ndppc-subfooter ul {
  gap: 0.8rem;
}

@media (max-width: 1199px) {
  .ndppc-footer {
    padding: 34px 0 20px;
  }

  .ndppc-footer-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .ndppc-footer-col {
    padding: 0.8rem 0.9rem 0.82rem;
  }

  .ndppc-footer-col:first-child,
  .ndppc-footer-col:last-child {
    grid-column: auto;
  }

  .ndppc-footer-col + .ndppc-footer-col {
    border-left: 0;
  }

  .ndppc-footer-col:nth-child(2n) {
    border-left: 1px solid rgba(255, 255, 255, 0.1);
  }

  .ndppc-footer-col:last-child,
  .ndppc-footer-col:nth-child(4) {
    border-left-color: rgba(20, 53, 38, 0.14);
  }

  .ndppc-footer-col:nth-child(n + 3) {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
  }

  .ndppc-footer-col:nth-child(4) {
    border-top-color: rgba(20, 53, 38, 0.14);
  }

  .ndppc-footer-map {
    min-height: 168px;
  }
}

@media (max-width: 767px) {
  .ndppc-footer {
    padding: 28px 0 16px;
  }

  .ndppc-footer-inner {
    grid-template-columns: 1fr;
  }

  .ndppc-footer-col {
    padding: 0.72rem 0.82rem 0.76rem;
    border-left: 0 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
  }

  .ndppc-footer-col:first-child {
    border-top: 0;
  }

  .ndppc-footer-col:last-child {
    border-top-color: rgba(20, 53, 38, 0.14);
  }

  .ndppc-footer-brand {
    margin-bottom: 0.7rem;
    padding-bottom: 0.62rem;
  }

  .ndppc-footer-brand img {
    width: 54px;
    height: 54px;
  }

  .ndppc-footer-col h3 {
    margin-bottom: 0.62rem;
  }

  .ndppc-footer-map {
    min-height: 148px;
  }

  .btn-last-update {
    margin-top: 0.6rem;
    width: auto;
  }

  .ndppc-subfooter {
    padding: 0.58rem 0 0.68rem;
  }
}

/* Final Research Footer Refresh */
.ndppc-footer {
  padding: 30px 0 16px;
  background:
    linear-gradient(180deg, rgba(236, 213, 160, 0.12), transparent 20%),
    linear-gradient(180deg, #153126 0%, #0a1813 100%);
  border-top: 3px solid #c6a45f;
}

.ndppc-footer-inner {
  grid-template-columns: minmax(255px, 1.14fr) minmax(168px, 0.9fr) minmax(182px, 0.96fr) minmax(220px, 0.78fr);
  gap: 0;
  padding: 1rem 0;
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.ndppc-footer-col {
  padding: 0 1.1rem;
  background: transparent !important;
}

.ndppc-footer-col + .ndppc-footer-col {
  border-left: 1px solid rgba(255, 255, 255, 0.1);
}

.ndppc-footer-col:last-child {
  border-left-color: rgba(231, 203, 142, 0.22);
}

.ndppc-footer-globe {
  min-height: 150px !important;
  height: 150px;
  margin-top: 0;
  border: 0 !important;
  background: transparent !important;
  overflow: visible;
  display: flex;
  justify-content: center;
  align-items: center;
}

.ndppc-footer-globe-shell {
  width: 150px;
  max-width: 100%;
  height: 150px;
  background: transparent !important;
}

.ndppc-footer-globe-stage {
  width: 150px;
  height: 150px;
  background: transparent !important;
}

.ndppc-footer-globe-script,
.ndppc-footer-globe-script > div,
.ndppc-footer-globe-script iframe,
.ndppc-footer-globe-script canvas {
  width: 150px !important;
  max-width: 150px !important;
  height: 150px !important;
  margin: 0 auto !important;
  background: transparent !important;
}

.ndppc-footer-brand {
  margin-bottom: 0.72rem;
  padding-bottom: 0.62rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}

.ndppc-footer-brand img {
  width: 56px;
  height: 56px;
  padding: 0.35rem;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(231, 203, 142, 0.2);
}

.ndppc-footer-brand strong {
  font-size: 1rem;
  line-height: 1.2;
}

.ndppc-footer-kicker {
  margin-bottom: 0.2rem !important;
  font-size: 0.68rem !important;
  letter-spacing: 0.14em;
}

.ndppc-footer-brand .mb-0 {
  line-height: 1.5;
}

.ndppc-footer-col h3 {
  margin: 0 0 0.55rem;
  padding-bottom: 0.42rem;
  border-bottom: 1px solid rgba(231, 203, 142, 0.24);
  color: #f0cf87;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.16em;
}

.ndppc-footer-col p,
.ndppc-footer-col a,
.ndppc-footer-col li {
  color: #eef3ee;
  font-size: 0.88rem;
  line-height: 1.36;
}

.ndppc-footer-col p {
  margin-bottom: 0.32rem;
}

.ndppc-footer-col ul {
  gap: 0.3rem;
}

.ndppc-footer-col:nth-child(2) a,
.ndppc-footer-col:nth-child(3) a {
  display: inline-flex;
  align-items: center;
  gap: 0.38rem;
  line-height: 1.3;
  color: #f4f8f4;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, color 0.18s ease, transform 0.18s ease, opacity 0.18s ease;
}

.ndppc-footer-col:nth-child(2) a::before,
.ndppc-footer-col:nth-child(3) a::before {
  color: #e0ba6e;
  font-size: 0.9rem;
}

.ndppc-footer-col a:hover,
.ndppc-footer-col a:focus-visible {
  color: #ffe3a8;
  text-decoration: none;
}

.ndppc-footer-col:nth-child(2) a:hover,
.ndppc-footer-col:nth-child(2) a:focus-visible,
.ndppc-footer-col:nth-child(3) a:hover,
.ndppc-footer-col:nth-child(3) a:focus-visible {
  background: rgba(231, 203, 142, 0.14);
  border-color: rgba(231, 203, 142, 0.34);
  transform: translateX(2px);
}

.ndppc-footer-col a:active {
  color: #f8c65d;
}

.ndppc-footer-map {
  min-height: 155px;
  margin-top: 0;
  border: 1px solid rgba(231, 203, 142, 0.26);
  background: #f3ecdd;
}

.ndppc-footer-globe {
  min-height: 155px;
  margin-top: 0;
  border: 1px solid rgba(231, 203, 142, 0.26);
  background: #f3ecdd;
  overflow: hidden;
}

.ndppc-footer-globe > div,
.ndppc-footer-globe iframe,
.ndppc-footer-globe canvas {
  width: 100% !important;
  max-width: 100% !important;
}

.btn-last-update {
  margin-top: 0.55rem;
  padding: 0.38rem 0.62rem;
  font-size: 0.72rem;
  letter-spacing: 0.03em;
}

.ndppc-subfooter {
  padding: 0.48rem 0 0.58rem;
  background: #08130f;
}

.ndppc-subfooter-inner {
  min-height: auto;
}

.ndppc-subfooter .copyright,
.ndppc-subfooter a {
  color: #e8eee7;
  font-size: 0.84rem;
}

.ndppc-subfooter-update {
  color: #f1cf88;
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

[data-site-footer].ndppc-footer {
  display: flex;
  flex-direction: column;
}

[data-site-footer].ndppc-footer > .ndppc-subfooter {
  margin-top: auto;
}

@media (max-width: 1199px) {
  .ndppc-footer {
    padding: 26px 0 14px;
  }

  .ndppc-footer-inner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    padding: 0.9rem 0;
  }

  .ndppc-footer-col {
    padding: 0.85rem 0.95rem;
  }

  .ndppc-footer-col:nth-child(2n + 1) {
    border-left: 0;
  }

  .ndppc-footer-col:nth-child(n + 3) {
    border-top: 1px solid rgba(255, 255, 255, 0.1);
  }

  .ndppc-footer-map {
    min-height: 145px;
  }

  .ndppc-footer-globe,
  .ndppc-footer-globe-shell,
  .ndppc-footer-globe-stage,
  .ndppc-footer-globe-script,
  .ndppc-footer-globe-script > div,
  .ndppc-footer-globe-script iframe,
  .ndppc-footer-globe-script canvas {
    min-height: 138px !important;
    height: 138px !important;
  }

  .ndppc-footer-globe-shell,
  .ndppc-footer-globe-stage,
  .ndppc-footer-globe-script,
  .ndppc-footer-globe-script > div,
  .ndppc-footer-globe-script iframe,
  .ndppc-footer-globe-script canvas {
    width: 138px !important;
    max-width: 138px !important;
  }
}

@media (max-width: 767px) {
  .ndppc-footer {
    padding: 22px 0 12px;
  }

  .ndppc-footer-inner {
    grid-template-columns: 1fr;
    padding: 0.7rem 0;
  }

  .ndppc-footer-col {
    padding: 0.72rem 0;
    border-left: 0 !important;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
  }

  .ndppc-footer-col:first-child {
    border-top: 0;
  }

  .ndppc-footer-brand {
    margin-bottom: 0.62rem;
    padding-bottom: 0.55rem;
  }

  .ndppc-footer-brand img {
    width: 50px;
    height: 50px;
  }

  .ndppc-footer-map {
    min-height: 128px;
  }

  .ndppc-footer-globe,
  .ndppc-footer-globe-shell,
  .ndppc-footer-globe-stage,
  .ndppc-footer-globe-script,
  .ndppc-footer-globe-script > div,
  .ndppc-footer-globe-script iframe,
  .ndppc-footer-globe-script canvas {
    min-height: 148px !important;
    height: 148px !important;
  }

  .ndppc-footer-globe {
    overflow: visible !important;
  }

  .ndppc-footer-globe-shell,
  .ndppc-footer-globe-stage,
  .ndppc-footer-globe-script,
  .ndppc-footer-globe-script > div,
  .ndppc-footer-globe-script iframe,
  .ndppc-footer-globe-script canvas {
    width: 148px !important;
    max-width: 148px !important;
  }

  .btn-last-update {
    margin-top: 0.48rem;
    width: auto;
  }

  .ndppc-subfooter {
    padding: 0.42rem 0 0.5rem;
  }
}

body[data-page="mission"] .banner.ndppc-mission-banner {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

body[data-page="mission"] .banner.ndppc-mission-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="mission"] .banner.ndppc-mission-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="mission"] .banner_content.ndppc-mission-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="mission"] .ndppc-mission-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height:170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="mission"] .ndppc-mission-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height:170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="mission"] .ndppc-mission-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="mission"] .ndppc-mission-banner-copy {
  position: absolute;
  inset: 0;
  display: grid;
  gap: 0.55rem;
  align-content: center;
  padding-top: 0.8rem;
  padding-bottom: 0.8rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="mission"] .ndppc-mission-banner-breadcrumbs {
  margin-bottom: 0;
}

body[data-page="mission"] .ndppc-mission-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.08;
}

body[data-page="mission"] .ndppc-mission-points-band {
  padding-top: 28px;
  padding-bottom: 14px;
}

body[data-page="mission"] .ndppc-mission-body-head {
  max-width: 1320px;
  margin: 0 auto 1.35rem;
  text-align: center;
}

body[data-page="mission"] .ndppc-mission-body-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
  line-height: 1.08;
}

body[data-page="mission"] .ndppc-mission-points-list {
  max-width: 1320px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.15rem;
}

body[data-page="mission"] .ndppc-mission-point {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 1.2rem;
  align-items: start;
  padding: 1.15rem 1.2rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 240, 227, 0.88));
}

body[data-page="mission"] .ndppc-mission-point-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  margin-top: 0.2rem;
  border-radius: 999px;
  background: #f3ecda;
  color: #8b6414;
}

body[data-page="mission"] .ndppc-mission-point-icon i {
  font-size: 1.22rem;
  line-height: 1;
}

body[data-page="mission"] .ndppc-mission-point-body {
  display: grid;
  align-content: start;
}

body[data-page="mission"] .ndppc-mission-point-copy {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.02rem, 1.28vw, 1.16rem);
  line-height: 1.72;
  text-align: justify;
}

body[data-page="mission"] .ndppc-mission-point-copy strong {
  font-weight: 800;
}

body[data-page="mission"] .ndppc-mission-goals-plain-band {
  padding-top: 10px;
  padding-bottom: 20px;
  background: rgba(236, 231, 220, 0.5);
}

body[data-page="mission"] .ndppc-mission-goals-plain {
  max-width: 1320px;
  display: grid;
  gap: 0;
}

body[data-page="mission"] .ndppc-mission-goals-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.15rem;
}

body[data-page="mission"] .ndppc-mission-goal-card {
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 1.1rem 1.15rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.94);
}

body[data-page="mission"] .ndppc-mission-goal-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  background: #f3ecda;
  color: #7b5c1f;
  font-size: 1rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="mission"] .ndppc-mission-goal-copy {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.75;
  text-align: justify;
}

body[data-page="mission"] .ndppc-mission-intro-band {
  padding-top: 30px;
  padding-bottom: 18px;
  background:
    linear-gradient(180deg, rgba(20, 53, 38, 0.04), rgba(20, 53, 38, 0)),
    linear-gradient(135deg, rgba(184, 146, 66, 0.08), rgba(255, 255, 255, 0.72));
}

body[data-page="mission"] .ndppc-mission-intro-layout {
  max-width: 1320px;
  display: grid;
  grid-template-columns: minmax(0, 1.14fr) minmax(300px, 0.86fr);
  gap: 2rem;
  align-items: start;
}

body[data-page="mission"] .ndppc-mission-intro-copy {
  display: grid;
  gap: 1rem;
  align-content: start;
}

body[data-page="mission"] .ndppc-mission-intro-copy h2,
body[data-page="mission"] .ndppc-mission-goals-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  line-height: 1.1;
}

body[data-page="mission"] .ndppc-mission-intro-copy h2 {
  font-size: clamp(1.8rem, 2.5vw, 2.65rem);
  max-width: 18ch;
}

body[data-page="mission"] .ndppc-mission-intro-copy .ndppc-card-copy,
body[data-page="mission"] .ndppc-mission-pillar-body .ndppc-card-copy,
body[data-page="mission"] .ndppc-mission-goals-copy .ndppc-card-copy,
body[data-page="mission"] .ndppc-mission-goal-row .ndppc-card-copy {
  text-align: justify;
}

body[data-page="mission"] .ndppc-mission-intro-panel {
  display: grid;
  gap: 1rem;
  align-content: start;
  padding: 1.35rem 1.4rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(246, 240, 227, 0.88));
}

body[data-page="mission"] .ndppc-mission-theme-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

body[data-page="mission"] .ndppc-mission-glance-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}

body[data-page="mission"] .ndppc-mission-glance-grid article {
  display: grid;
  gap: 0.25rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="mission"] .ndppc-mission-glance-grid strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.7rem;
  line-height: 1;
}

body[data-page="mission"] .ndppc-mission-glance-grid span {
  color: var(--ndppc-copy);
  font-size: 0.92rem;
  font-weight: 700;
}

body[data-page="mission"] .ndppc-mission-section-head {
  margin-bottom: 1.75rem;
}

body[data-page="mission"] .ndppc-mission-section-copy {
  max-width: 760px;
}

body[data-page="mission"] .ndppc-mission-pillar-band {
  padding-top: 14px;
  padding-bottom: 16px;
}

body[data-page="mission"] .ndppc-mission-pillar-stack {
  display: grid;
  max-width: 1320px;
  gap: 0;
}

body[data-page="mission"] .ndppc-mission-pillar,
body[data-page="mission"] .ndppc-mission-goal {
  display: grid;
  gap: 0.75rem;
  align-content: start;
  padding: 1.3rem 1.35rem;
  border-radius: 24px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.92);
}

body[data-page="mission"] .ndppc-mission-pillar-row {
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 1.15rem 0;
  border: 0;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
  border-radius: 0;
  background: transparent;
}

body[data-page="mission"] .ndppc-mission-pillar-row:first-child {
  padding-top: 0;
  border-top: 0;
}

body[data-page="mission"] .ndppc-mission-pillar-index {
  display: flex;
  justify-content: flex-start;
}

body[data-page="mission"] .ndppc-mission-pillar-body {
  display: grid;
  gap: 0.55rem;
}

body[data-page="mission"] .ndppc-mission-pillar h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.2rem;
  line-height: 1.3;
}

body[data-page="mission"] .ndppc-mission-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: #f3ecda;
  color: #7b5c1f;
  font-size: 1.05rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="mission"] .ndppc-mission-goals-band {
  background: rgba(236, 231, 220, 0.72);
}

body[data-page="mission"] .ndppc-mission-goals-wrap {
  max-width: 1320px;
  display: grid;
  grid-template-columns: minmax(0, 0.94fr) minmax(0, 1.06fr);
  gap: 2rem;
  align-items: start;
}

body[data-page="mission"] .ndppc-mission-goals-copy {
  display: grid;
  gap: 1rem;
  align-content: start;
}

body[data-page="mission"] .ndppc-mission-goals-copy h3 {
  font-size: clamp(1.7rem, 2.6vw, 2.35rem);
}

body[data-page="mission"] .ndppc-mission-goal-list-structured {
  gap: 0.85rem;
}

body[data-page="mission"] .ndppc-mission-goal-list {
  display: grid;
  gap: 1rem;
}

body[data-page="mission"] .ndppc-mission-goal-row {
  grid-template-columns: 52px minmax(0, 1fr);
  align-items: start;
  gap: 1rem;
  padding: 1rem 1.1rem;
  border-radius: 18px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  border-left: 4px solid rgba(184, 146, 66, 0.7);
  background: rgba(255, 255, 255, 0.86);
}

body[data-page="mission"] .ndppc-mission-goal .ndppc-card-copy {
  margin-top: 0.15rem;
}

body[data-page="mission"] .ndppc-mission-link-grid .ndppc-link-card {
  min-height: 100%;
}

@media (max-width: 991px) {
  body[data-page="mission"] .ndppc-mission-points-list,
  body[data-page="mission"] .ndppc-mission-goals-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="mission"] .ndppc-mission-point {
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 1rem;
  }

  body[data-page="mission"] .ndppc-mission-intro-layout,
  body[data-page="mission"] .ndppc-mission-goals-wrap {
    grid-template-columns: 1fr;
  }

  body[data-page="mission"] .ndppc-mission-banner-frame,
  body[data-page="mission"] .ndppc-mission-banner-frame img {
    min-height: 102px;
  }

  body[data-page="mission"] .ndppc-mission-intro-copy h2 {
    max-width: none;
  }
}

@media (max-width: 767px) {
  body[data-page="mission"] .ndppc-mission-points-band {
    padding-top: 22px;
    padding-bottom: 10px;
  }

  body[data-page="mission"] .ndppc-mission-body-head {
    margin-bottom: 1rem;
  }

  body[data-page="mission"] .ndppc-mission-body-head h2 {
    font-size: 1.52rem;
  }

  body[data-page="mission"] .ndppc-mission-point {
    grid-template-columns: 1fr;
    gap: 0.8rem;
    padding: 0.95rem 1rem;
  }

  body[data-page="mission"] .ndppc-mission-point-icon {
    width: 40px;
    height: 40px;
  }

  body[data-page="mission"] .ndppc-mission-point-copy {
    font-size: 1rem;
  }

  body[data-page="mission"] .ndppc-mission-goal-card {
    grid-template-columns: 1fr;
    gap: 0.8rem;
    padding: 0.95rem 1rem;
  }

  body[data-page="mission"] .ndppc-mission-banner-frame,
  body[data-page="mission"] .ndppc-mission-banner-frame img {
    min-height: 88px;
  }

  body[data-page="mission"] .ndppc-mission-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="mission"] .ndppc-mission-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="mission"] .ndppc-mission-intro-band {
    padding-top: 24px;
    padding-bottom: 12px;
  }

  body[data-page="mission"] .ndppc-mission-intro-copy h2,
  body[data-page="mission"] .ndppc-mission-goals-copy h3 {
    font-size: 1.8rem;
  }

  body[data-page="mission"] .ndppc-mission-glance-grid,
  body[data-page="mission"] .ndppc-mission-pillar-row,
  body[data-page="mission"] .ndppc-mission-goal-row {
    grid-template-columns: 1fr;
  }

  body[data-page="mission"] .ndppc-mission-intro-panel {
    padding: 1.05rem 1rem;
  }

  body[data-page="mission"] .ndppc-mission-pillar-row {
    gap: 0.8rem;
    padding: 1rem 0;
  }

  body[data-page="mission"] .ndppc-mission-pillar-index {
    justify-content: flex-start;
  }

  body[data-page="mission"] .ndppc-mission-goal-row {
    gap: 0.8rem;
    padding: 0.95rem 1rem;
  }
}

body[data-page="about"] .ndppc-about-intro {
  display: grid;
  grid-template-columns: minmax(0, 1.06fr) minmax(340px, 0.94fr);
  gap: 1.5rem;
  align-items: start;
}

body[data-page="about"] .ndppc-about-story {
  display: grid;
  gap: 1rem;
  align-content: start;
}

body[data-page="about"] .ndppc-about-story h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(2rem, 2.9vw, 2.8rem);
  line-height: 1.12;
}

body[data-page="about"] .ndppc-about-story .ndppc-card-copy {
  margin: 0;
  text-align: justify;
}

body[data-page="about"] .ndppc-about-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.9rem;
  margin-top: 0.15rem;
}

body[data-page="about"] .ndppc-about-actions .material-symbols-outlined {
  font-size: 1.08rem;
  margin-right: 0.32rem;
  vertical-align: middle;
}

body[data-page="about"] .ndppc-about-media {
  display: grid;
  gap: 1rem;
}

body[data-page="about"] .ndppc-about-feature {
  display: grid;
  gap: 0.95rem;
}

body[data-page="about"] .ndppc-about-feature img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  border-radius: 14px;
}

body[data-page="about"] .ndppc-about-feature-copy {
  display: grid;
  gap: 0.55rem;
}

body[data-page="about"] .ndppc-about-feature-copy h3 {
  margin: 0;
  font-size: 1.42rem;
  color: var(--ndppc-primary-dark);
}

body[data-page="about"] .ndppc-about-photo-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="about"] .ndppc-about-photo-card {
  display: grid;
  gap: 0.75rem;
  align-content: start;
}

body[data-page="about"] .ndppc-about-photo-card img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 12px;
}

body[data-page="about"] .ndppc-about-photo-card strong {
  display: block;
  margin-bottom: 0.2rem;
  color: var(--ndppc-primary-dark);
}

body[data-page="about"] .ndppc-about-stat-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body[data-page="about"] .ndppc-about-stat-card {
  gap: 0.85rem;
}

body[data-page="about"] .ndppc-about-stat-card .ndppc-count {
  font-size: clamp(1.72rem, 2.45vw, 2.38rem);
  line-height: 1;
  color: var(--ndppc-primary-dark);
}

body[data-page="about"] .ndppc-about-capability-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body[data-page="about"] .ndppc-about-direction-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.25rem;
  margin-top: 1.5rem;
}

body[data-page="about"] .ndppc-about-direction-grid .ndppc-copy-card,
body[data-page="about"] .ndppc-about-link-grid .ndppc-link-card {
  height: 100%;
}

body[data-page="about"] .ndppc-about-link-grid {
  margin-top: 1.25rem;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body[data-page="about"] .ndppc-about-link-grid .ndppc-link-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 235, 0.96));
}

body[data-page="about"] .ndppc-about-link-grid .ndppc-link-card .rounded-pill {
  width: max-content;
}

@media (max-width: 1199px) {
  body[data-page="about"] .ndppc-about-intro,
  body[data-page="about"] .ndppc-about-direction-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="about"] .ndppc-about-photo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body[data-page="about"] .ndppc-about-stat-grid,
  body[data-page="about"] .ndppc-about-capability-grid,
  body[data-page="about"] .ndppc-about-link-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  body[data-page="about"] .ndppc-about-story h2 {
    font-size: 1.7rem;
  }

  body[data-page="about"] .ndppc-about-actions {
    gap: 0.75rem;
  }

  body[data-page="about"] .ndppc-about-photo-grid,
  body[data-page="about"] .ndppc-about-stat-grid,
  body[data-page="about"] .ndppc-about-capability-grid,
  body[data-page="about"] .ndppc-about-link-grid {
    grid-template-columns: 1fr;
  }
}

.ndppc-home-logo-marquee {
  position: relative;
  width: 100%;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
  mask-image: linear-gradient(to right, transparent, #000 6%, #000 94%, transparent);
}

.ndppc-home-logo-marquee-track {
  display: flex;
  align-items: center;
  width: max-content;
  will-change: transform;
  animation: ndppc-logo-marquee 28s linear infinite;
}

.ndppc-home-logo-marquee-group {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  flex-shrink: 0;
}

.ndppc-home-logo-marquee-group .ndppc-home-logo-slide {
  width: auto;
  min-width: clamp(104px, 7vw, 138px);
  flex: 0 0 auto;
  padding: 0 0.12rem;
}

.ndppc-home-logo-marquee-group .ndppc-home-logo-mark {
  width: auto;
  min-width: 0;
}

@keyframes ndppc-logo-marquee {
  from {
    transform: translate3d(0, 0, 0);
  }

  to {
    transform: translate3d(-50%, 0, 0);
  }
}

@media (max-width: 991px) {
  .ndppc-home-logo-marquee-track {
    animation-duration: 22s;
  }

  .ndppc-home-logo-marquee-group .ndppc-home-logo-slide {
    min-width: 92px;
    padding: 0 0.08rem;
  }
}

@media (max-width: 767px) {
  .ndppc-home-logo-marquee {
    -webkit-mask-image: none;
    mask-image: none;
  }

  .ndppc-home-logo-marquee-track {
    animation-duration: 18s;
  }

  .ndppc-home-logo-marquee-group {
    gap: 0.12rem;
  }

  .ndppc-home-logo-marquee-group .ndppc-home-logo-slide {
    min-width: 74px;
    padding: 0 0.04rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ndppc-home-logo-marquee-track {
    animation: none;
  }
}

.ndppc-home-network-band,
.ndppc-home-logo-track {
  background: var(--ndppc-surface);
}

.ndppc-home-logo-slide img {
  max-height: 100px;
  max-width: 120px;
}

@media (max-width: 991px) {
  .ndppc-home-logo-slide img {
    max-height: 74px;
  }
}

@media (max-width: 767px) {
  .ndppc-home-logo-slide img {
    max-height: 50px;
  }
}

body[data-page="about"] .banner.ndppc-about-banner {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

body[data-page="about"] .banner.ndppc-about-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="about"] .banner.ndppc-about-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="about"] .banner_content.ndppc-about-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="about"] .ndppc-about-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="about"] .ndppc-about-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="about"] .ndppc-about-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="about"] .ndppc-about-banner-copy {
  display: grid;
  gap: 1rem;
  width: 100%;
  max-width: none;
  margin: 0;
  position: absolute;
  inset: 0;
  align-content: center;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="about"] .ndppc-about-banner-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="about"] .ndppc-about-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="about"] .ndppc-about-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.08;
}

body[data-page="about"] .ndppc-about-text-hero {
  padding: 38px 0 18px;
  background:
    linear-gradient(180deg, rgba(20, 53, 38, 0.04), rgba(20, 53, 38, 0)),
    linear-gradient(135deg, rgba(184, 146, 66, 0.08), rgba(255, 255, 255, 0.68));
}

body[data-page="about"] .ndppc-about-text-hero .container,
body[data-page="about"] .ndppc-about-text-section .container {
  max-width: 1320px;
}

body[data-page="about"] .ndppc-about-text-breadcrumb {
  margin-bottom: 1rem;
}

body[data-page="about"] .ndppc-about-text-breadcrumb a {
  color: var(--ndppc-primary);
}

body[data-page="about"] .ndppc-about-text-head {
  max-width: 1320px;
  display: grid;
  gap: 0.95rem;
}

body[data-page="about"] .ndppc-about-text-head h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(2.1rem, 3vw, 3.15rem);
  line-height: 1.08;
}

body[data-page="about"] .ndppc-about-text-head p,
body[data-page="about"] .ndppc-about-text-block p,
body[data-page="about"] .ndppc-about-text-block li {
  margin: 0;
  color: var(--ndppc-copy);
  font-size: 1rem;
  line-height: 1.95;
  text-align: justify;
}

body[data-page="about"] .ndppc-about-text-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
  padding-top: 0.2rem;
}

body[data-page="about"] .ndppc-about-text-links a {
  color: var(--ndppc-primary);
  font-weight: 700;
  text-decoration: none;
}

body[data-page="about"] .ndppc-about-text-links span {
  color: rgba(20, 53, 38, 0.4);
}

body[data-page="about"] .ndppc-about-text-section {
  padding-top: 20px;
}

body[data-page="about"] .ndppc-about-text-flow {
  max-width: 1320px;
  display: grid;
  gap: 2.1rem;
}

body[data-page="about"] .ndppc-about-text-block {
  display: grid;
  gap: 0.95rem;
  padding-bottom: 1.9rem;
  border-bottom: 1px solid rgba(20, 53, 38, 0.1);
}

body[data-page="about"] .ndppc-about-text-block:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

body[data-page="about"] .ndppc-about-text-block h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.4rem, 2vw, 1.95rem);
  line-height: 1.2;
}

body[data-page="about"] .ndppc-about-closing-block p:first-of-type {
  color: var(--ndppc-primary-dark);
  font-size: 1.06rem;
  line-height: 1.95;
}

body[data-page="about"] .ndppc-about-story-section {
  padding-top: 26px;
  padding-bottom: 12px;
}

body[data-page="about"] .ndppc-about-story-grid {
  max-width: 1320px;
  display: grid;
  grid-template-columns: minmax(0, 1.28fr) minmax(300px, 0.82fr);
  gap: 2rem;
  align-items: start;
}

body[data-page="about"] .ndppc-about-lead {
  display: grid;
  gap: 1rem;
}

body[data-page="about"] .ndppc-about-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: #8b6414;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body[data-page="about"] .ndppc-about-kicker::before {
  content: "";
  width: 26px;
  height: 1px;
  background: rgba(139, 100, 20, 0.45);
}

body[data-page="about"] .ndppc-about-lead h2,
body[data-page="about"] .ndppc-about-section-head h2,
body[data-page="about"] .ndppc-about-role-copy h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  line-height: 1.08;
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
}

body[data-page="about"] .ndppc-about-lead h2 {
  max-width: none;
}

body[data-page="about"] .ndppc-about-inline-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
  padding-top: 0.35rem;
}

body[data-page="about"] .ndppc-about-inline-links a {
  color: var(--ndppc-primary);
  font-weight: 700;
  text-decoration: none;
}

body[data-page="about"] .ndppc-about-inline-links span {
  color: rgba(20, 53, 38, 0.38);
}

body[data-page="about"] .ndppc-about-facts {
  display: grid;
  gap: 1rem;
  padding: 1.35rem 1.4rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(246, 240, 227, 0.86));
  border: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="about"] .ndppc-about-fact-list {
  display: grid;
  gap: 0.95rem;
  margin: 0;
}

body[data-page="about"] .ndppc-about-fact-list div {
  display: grid;
  gap: 0.28rem;
  padding-top: 0.85rem;
  border-top: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="about"] .ndppc-about-fact-list div:first-child {
  padding-top: 0;
  border-top: 0;
}

body[data-page="about"] .ndppc-about-fact-list dt {
  color: var(--ndppc-primary-dark);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="about"] .ndppc-about-fact-list dd {
  margin: 0;
  color: var(--ndppc-copy);
  line-height: 1.75;
}

body[data-page="about"] .ndppc-about-section-band {
  padding-top: 20px;
  padding-bottom: 12px;
}

body[data-page="about"] .ndppc-about-section-head {
  max-width: 1320px;
  display: grid;
  gap: 0.55rem;
  margin-bottom: 1.35rem;
}

body[data-page="about"] .ndppc-about-article-grid {
  max-width: 1320px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.8rem 2rem;
}

body[data-page="about"] .ndppc-about-article-grid-wide {
  gap: 1.9rem 2rem;
}

body[data-page="about"] .ndppc-about-article,
body[data-page="about"] .ndppc-about-solution {
  display: grid;
  gap: 0.7rem;
  align-content: start;
  padding-top: 1rem;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
}

body[data-page="about"] .ndppc-about-article h3,
body[data-page="about"] .ndppc-about-solution h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.12rem;
  line-height: 1.35;
}

body[data-page="about"] .ndppc-about-solution-list {
  max-width: 1320px;
  display: grid;
  gap: 1rem;
}

body[data-page="about"] .ndppc-about-role-band {
  padding-top: 18px;
  padding-bottom: 10px;
}

body[data-page="about"] .ndppc-about-role-layout {
  max-width: 1320px;
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(240px, 0.82fr);
  gap: 2rem;
  align-items: start;
}

body[data-page="about"] .ndppc-about-role-copy {
  display: grid;
  gap: 0.9rem;
}

body[data-page="about"] .ndppc-about-story-section p,
body[data-page="about"] .ndppc-about-section-band p,
body[data-page="about"] .ndppc-about-role-band p,
body[data-page="about"] .ndppc-about-fact-list dd {
  text-align: justify;
}

body[data-page="about"] .ndppc-about-next-links {
  display: grid;
  gap: 0.8rem;
  align-content: start;
  padding-top: 0.2rem;
  padding-left: 1.25rem;
  border-left: 1px solid rgba(20, 53, 38, 0.12);
}

body[data-page="about"] .ndppc-about-next-links a {
  color: var(--ndppc-primary);
  font-weight: 700;
  text-decoration: none;
}

body[data-page="about"] .ndppc-about-text-list {
  margin: 0;
  padding-left: 1.2rem;
}

body[data-page="about"] .ndppc-about-text-list li + li {
  margin-top: 0.55rem;
}

@media (max-width: 991px) {
  body[data-page="about"] .ndppc-about-banner-frame,
  body[data-page="about"] .ndppc-about-banner-frame img {
    min-height: 102px;
  }

  body[data-page="about"] .ndppc-about-story-grid,
  body[data-page="about"] .ndppc-about-role-layout,
  body[data-page="about"] .ndppc-about-article-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="about"] .ndppc-about-next-links {
    padding-left: 0;
    border-left: 0;
    padding-top: 0.4rem;
    border-top: 1px solid rgba(20, 53, 38, 0.12);
  }
}

@media (max-width: 767px) {
  body[data-page="about"] .ndppc-about-banner-frame,
  body[data-page="about"] .ndppc-about-banner-frame img {
    min-height: 88px;
  }

  body[data-page="about"] .ndppc-about-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="about"] .ndppc-about-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="about"] .ndppc-about-story-section,
  body[data-page="about"] .ndppc-about-section-band,
  body[data-page="about"] .ndppc-about-role-band {
    padding-top: 16px;
    padding-bottom: 8px;
  }

  body[data-page="about"] .ndppc-about-lead h2,
  body[data-page="about"] .ndppc-about-section-head h2,
  body[data-page="about"] .ndppc-about-role-copy h2 {
    font-size: 1.52rem;
  }

  body[data-page="about"] .ndppc-about-story-grid,
  body[data-page="about"] .ndppc-about-article-grid,
  body[data-page="about"] .ndppc-about-solution-list,
  body[data-page="about"] .ndppc-about-role-layout {
    gap: 1.35rem;
  }

  body[data-page="about"] .ndppc-about-facts {
    padding: 1.05rem 1rem;
  }

  body[data-page="about"] .ndppc-about-text-hero {
    padding: 28px 0 14px;
  }

  body[data-page="about"] .ndppc-about-text-head h1 {
    font-size: 1.95rem;
  }

  body[data-page="about"] .ndppc-about-text-head p,
  body[data-page="about"] .ndppc-about-text-block p,
  body[data-page="about"] .ndppc-about-text-block li {
    text-align: left;
    line-height: 1.8;
  }

  body[data-page="about"] .ndppc-about-text-flow {
    gap: 1.7rem;
  }

  body[data-page="about"] .ndppc-about-text-block {
    padding-bottom: 1.55rem;
  }
}

body[data-page="team"] .ndppc-team-page-shell .container {
  max-width: 1320px;
}

body[data-page="team"] .ndppc-team-page-shell {
  padding-top: 0;
}

body[data-page="team"] .banner.ndppc-team-banner {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

body[data-page="team"] .banner.ndppc-team-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="team"] .banner.ndppc-team-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="team"] .banner_content.ndppc-team-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="team"] .ndppc-team-banner-frame {
  position: relative;
  width: 100%;
  min-height: 100px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="team"] .ndppc-team-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 178px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="team"] .ndppc-team-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="team"] .ndppc-team-page-head {
  display: grid;
  gap: 1rem;
  width: 100%;
  max-width: none;
  margin: 0;
  position: absolute;
  inset: 0;
  align-content: center;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="team"] .ndppc-team-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="team"] .ndppc-team-stats article {
  display: grid;
  gap: 0.35rem;
  padding: 1rem 1.15rem;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 237, 222, 0.92));
  box-shadow: 0 16px 30px rgba(20, 53, 38, 0.05);
}

body[data-page="team"] .ndppc-team-stats strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.95rem;
  line-height: 1;
}

body[data-page="team"] .ndppc-team-stats span {
  color: var(--ndppc-copy);
  font-weight: 700;
}

body[data-page="team"] .ndppc-team-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 280px);
  gap: 0.85rem;
  align-items: center;
  margin-bottom: 0.95rem;
}

body[data-page="team"] .ndppc-team-filter-row {
  margin-bottom: 0;
}

body[data-page="team"] .ndppc-team-search-box {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  min-height: 44px;
  padding: 0 0.85rem;
  border-radius: 999px;
  border: 1px solid rgba(20, 53, 38, 0.14);
  background: rgba(255, 255, 255, 0.9);
  width: 100%;
}

body[data-page="team"] .ndppc-team-search-box .material-symbols-outlined {
  color: var(--ndppc-primary);
  font-size: 1rem;
}

body[data-page="team"] .ndppc-team-search-box input {
  width: 100%;
  min-width: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  font-size: 0.94rem;
}

body[data-page="team"] .ndppc-team-filter-row button {
  border-radius: 999px;
}

body[data-page="team"] .ndppc-team-feature-wrap {
  margin-bottom: 1.5rem;
}

body[data-page="team"] .ndppc-team-feature-card {
  display: grid;
  grid-template-columns: minmax(320px, 390px) minmax(0, 1fr);
  gap: 0;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 237, 222, 0.92));
  box-shadow: 0 26px 46px rgba(18, 37, 28, 0.08);
}

body[data-page="team"] .ndppc-team-feature-media {
  background: rgba(244, 237, 222, 0.9);
}

body[data-page="team"] .ndppc-team-feature-media img {
  width: 100%;
  height: 100%;
  min-height: 420px;
  display: block;
  object-fit: cover;
}

body[data-page="team"] .ndppc-team-feature-copy {
  display: grid;
  gap: 0.95rem;
  align-content: center;
  padding: 1.6rem 1.7rem;
}

body[data-page="team"] .ndppc-team-feature-top {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  flex-wrap: wrap;
}

body[data-page="team"] .ndppc-team-feature-kicker {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.38rem 0.7rem;
  border-radius: 999px;
  background: rgba(25, 67, 50, 0.08);
  color: var(--ndppc-primary-dark);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="team"] .ndppc-team-feature-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(2rem, 2.55vw, 2.85rem);
}

body[data-page="team"] .ndppc-team-feature-role {
  margin: 0;
  color: #8a6521;
  font-size: 1.02rem;
  font-weight: 700;
}

body[data-page="team"] .ndppc-team-feature-copy p {
  margin: 0;
  color: var(--ndppc-copy);
  line-height: 1.85;
}

body[data-page="team"] .ndppc-team-feature-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

body[data-page="team"] .ndppc-team-feature-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0.48rem 0.82rem;
  border-radius: 999px;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: rgba(255, 255, 255, 0.72);
  color: var(--ndppc-primary-dark);
  font-size: 0.84rem;
  font-weight: 700;
}

body[data-page="team"] .ndppc-team-directory-wrap {
  display: grid;
  gap: 1.7rem;
}

body[data-page="team"] .ndppc-team-group {
  display: grid;
  gap: 1.1rem;
}

body[data-page="team"] .ndppc-team-group-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 0.85rem;
  border-bottom: 1px solid rgba(20, 53, 38, 0.12);
}

body[data-page="team"] .ndppc-team-group-head h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.5rem;
}

body[data-page="team"] .ndppc-team-group-head p {
  margin: 0.35rem 0 0;
  color: var(--ndppc-copy);
  line-height: 1.75;
}

body[data-page="team"] .ndppc-team-group-head strong {
  color: var(--ndppc-primary);
  font-size: 2rem;
  line-height: 1;
}

body[data-page="team"] .ndppc-team-group-note {
  gap: 0;
}

body[data-page="team"] .ndppc-team-page-grid {
  display: grid;
  gap: 1.15rem;
}

body[data-page="team"] .ndppc-team-page-grid-associate {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page="team"] .ndppc-team-page-grid-scholar {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body[data-page="team"] .ndppc-team-directory-card {
  display: grid;
  grid-template-columns: 156px minmax(0, 1fr);
  gap: 0;
  height: 100%;
  overflow: hidden;
  border-radius: 24px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 237, 222, 0.94));
  box-shadow: 0 14px 26px rgba(18, 37, 28, 0.05);
}

body[data-page="team"] .ndppc-team-directory-card-associate {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 237, 222, 0.94));
}

body[data-page="team"] .ndppc-team-directory-card-lead {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(241, 246, 243, 0.95));
}

body[data-page="team"] .ndppc-team-directory-media {
  display: flex;
}

body[data-page="team"] .ndppc-team-directory-media img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
}

body[data-page="team"] .ndppc-team-directory-copy {
  display: grid;
  gap: 0.6rem;
  align-content: start;
  padding: 1rem 1.05rem 1.05rem;
}

body[data-page="team"] .ndppc-team-directory-top {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

body[data-page="team"] .ndppc-team-directory-copy .rounded-pill,
body[data-page="team"] .ndppc-team-scholar-copy .rounded-pill {
  justify-self: start;
}

body[data-page="team"] .ndppc-team-directory-copy h4,
body[data-page="team"] .ndppc-team-scholar-copy h4 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.15rem;
}

body[data-page="team"] .ndppc-team-card-role {
  margin: 0;
  color: #8a6521;
  font-size: 0.95rem;
  font-weight: 700;
}

body[data-page="team"] .ndppc-person-card-note {
  color: var(--ndppc-copy);
  line-height: 1.68;
  margin: 0;
}

body[data-page="team"] .ndppc-team-directory-copy .ndppc-card-actions,
body[data-page="team"] .ndppc-team-scholar-copy .ndppc-card-actions {
  margin-top: auto;
  padding-top: 0.15rem;
}

body[data-page="team"] .ndppc-team-scholar-card {
  display: grid;
  overflow: hidden;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(241, 246, 243, 0.94));
  box-shadow: 0 12px 24px rgba(18, 37, 28, 0.05);
}

body[data-page="team"] .ndppc-team-scholar-media img {
  width: 100%;
  height: 220px;
  display: block;
  object-fit: cover;
}

body[data-page="team"] .ndppc-team-scholar-copy {
  display: grid;
  gap: 0.55rem;
  padding: 1rem 1.05rem 1.05rem;
}

body[data-page="team"] .ndppc-team-empty {
  padding: 1.5rem;
  border-radius: 24px;
  border: 1px dashed rgba(20, 53, 38, 0.18);
  background: rgba(255, 255, 255, 0.7);
}

body[data-page="team"] .ndppc-team-empty h3 {
  margin: 0 0 0.45rem;
  color: var(--ndppc-primary-dark);
}

body[data-page="team"] .ndppc-team-empty p {
  margin: 0;
  color: var(--ndppc-copy);
}

@media (max-width: 1199px) {
  body[data-page="team"] .ndppc-team-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="team"] .ndppc-team-feature-card {
    grid-template-columns: 320px minmax(0, 1fr);
  }

  body[data-page="team"] .ndppc-team-page-grid-associate,
  body[data-page="team"] .ndppc-team-page-grid-scholar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body[data-page="team"] .ndppc-team-controls {
    grid-template-columns: 1fr;
  }

  body[data-page="team"] .ndppc-team-feature-card {
    grid-template-columns: 1fr;
  }

  body[data-page="team"] .ndppc-team-feature-media img {
    height: clamp(320px, 62vw, 440px);
    min-height: 0;
  }

  body[data-page="team"] .ndppc-team-directory-card {
    grid-template-columns: 136px minmax(0, 1fr);
  }
}

@media (max-width: 767px) {
  body[data-page="team"] .ndppc-team-page-shell {
    padding-top: 26px;
  }

  body[data-page="team"] .ndppc-team-stats,
  body[data-page="team"] .ndppc-team-page-grid-associate,
  body[data-page="team"] .ndppc-team-page-grid-scholar {
    grid-template-columns: 1fr;
  }

  body[data-page="team"] .ndppc-team-group-head {
    flex-direction: column;
    align-items: start;
  }

  body[data-page="team"] .ndppc-team-feature-card {
    padding: 1.05rem;
  }

  body[data-page="team"] .ndppc-team-feature-copy {
    padding: 0;
  }

  body[data-page="team"] .ndppc-team-feature-copy h3 {
    font-size: 1.85rem;
  }

  body[data-page="team"] .ndppc-team-directory-card {
    grid-template-columns: 112px minmax(0, 1fr);
  }

  body[data-page="team"] .ndppc-team-directory-copy {
    padding: 0.85rem 0.9rem 0.95rem;
  }

  body[data-page="team"] .ndppc-team-scholar-media img {
    height: 250px;
  }
}

body[data-page="team"] .ndppc-team-page-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  color: rgba(20, 53, 38, 0.62);
  font-weight: 600;
}

body[data-page="team"] .ndppc-team-page-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="team"] .ndppc-team-page-head h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.08;
}

body[data-page="team"] .ndppc-team-page-head p {
  margin: 0;
  color: var(--ndppc-copy);
  line-height: 1.85;
}

body[data-page="team"] .ndppc-team-controls {
  margin-bottom: 1.25rem;
}

body[data-page="team"] .ndppc-team-personnel-layout {
  grid-template-columns: minmax(360px, 1.02fr) minmax(420px, 0.98fr);
  align-items: start;
}

body[data-page="team"] .ndppc-team-personnel-layout-lead-only {
  grid-template-columns: minmax(0, 920px);
  justify-content: center;
  margin-inline: auto;
}

body[data-page="team"] .ndppc-team-page-intro {
  margin-bottom: 0.2rem;
}

body[data-page="team"] .ndppc-team-directory-overview {
  display: grid;
  gap: 1rem;
  padding: 1.2rem 1.25rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 242, 233, 0.96));
  box-shadow: 0 14px 26px rgba(18, 37, 28, 0.04);
}

body[data-page="team"] .ndppc-team-directory-overview-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
}

body[data-page="team"] .ndppc-team-directory-intro {
  gap: 0.45rem;
}

body[data-page="team"] .ndppc-team-directory-intro h3 {
  font-size: clamp(1.5rem, 2.1vw, 2rem);
}

body[data-page="team"] .ndppc-team-directory-intro p {
  max-width: 64ch;
  color: var(--ndppc-copy);
  line-height: 1.75;
}

body[data-page="team"] .ndppc-team-directory-meta {
  min-width: 128px;
  min-height: 118px;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 0.22rem;
  padding: 0.9rem 1rem;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: rgba(255, 255, 255, 0.92);
}

body[data-page="team"] .ndppc-team-directory-meta .material-symbols-outlined {
  color: var(--ndppc-primary);
  font-size: 1.4rem;
}

body[data-page="team"] .ndppc-team-directory-meta strong {
  color: var(--ndppc-primary-dark);
  font-size: 2rem;
  line-height: 1;
}

body[data-page="team"] .ndppc-team-directory-meta small {
  color: var(--ndppc-copy-soft);
  font-size: 0.8rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

body[data-page="team"] .ndppc-team-directory-overview-body {
  display: grid;
}

body[data-page="team"] .ndppc-team-overview-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

body[data-page="team"] .ndppc-team-overview-stat {
  display: grid;
  gap: 0.25rem;
  padding: 0.95rem 1rem;
  border-radius: 18px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.8);
}

body[data-page="team"] .ndppc-team-overview-stat strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.55rem;
  line-height: 1;
}

body[data-page="team"] .ndppc-team-overview-stat span {
  color: var(--ndppc-copy);
  font-size: 0.9rem;
  font-weight: 700;
}

body[data-page="team"] .ndppc-team-feature-wrap {
  margin-bottom: 1.85rem;
}

body[data-page="team"] .ndppc-team-feature-wrap {
  justify-items: center;
}

body[data-page="team"] .ndppc-team-directory-wrap {
  gap: 1.85rem;
}

body[data-page="team"] .ndppc-team-band {
  gap: 1.15rem;
}

body[data-page="team"] .ndppc-team-band-head {
  align-items: end;
  gap: 1.2rem;
}

body[data-page="team"] .ndppc-team-band-head p {
  max-width: 68ch;
}

body[data-page="team"] .ndppc-team-band-head strong {
  min-width: 62px;
  min-height: 62px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 237, 222, 0.92));
  border: 1px solid rgba(20, 53, 38, 0.1);
  color: var(--ndppc-primary-dark);
  font-size: 1.45rem;
  line-height: 1;
  box-shadow: 0 12px 20px rgba(18, 37, 28, 0.04);
}

body[data-page="team"] .ndppc-team-band-associate .ndppc-team-band-head strong {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 237, 222, 0.94));
}

body[data-page="team"] .ndppc-team-band-scholar .ndppc-team-band-head strong {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(241, 246, 243, 0.94));
}

body[data-page="team"] .ndppc-team-page-roster,
body[data-page="team"] .ndppc-team-page-roster-only {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
  align-content: start;
  height: auto;
}

body[data-page="team"] .ndppc-team-page-stage-only {
  max-width: 920px;
  width: 100%;
  margin-inline: auto;
}

body[data-page="team"] .ndppc-team-page-grid {
  display: grid;
  gap: 1rem;
}

body[data-page="team"] .ndppc-team-page-grid-associate,
body[data-page="team"] .ndppc-team-page-grid-scholar {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page="team"] .ndppc-team-page-mini {
  height: 100%;
  grid-template-columns: 156px minmax(0, 1fr);
  gap: 1rem;
}

body[data-page="team"] .ndppc-team-page-mini .ndppc-home-team-mini-media {
  min-width: 156px;
}

body[data-page="team"] .ndppc-team-page-mini .ndppc-home-team-mini-media img {
  width: 156px;
  height: 182px;
  min-height: 182px;
}

body[data-page="team"] .ndppc-team-page-mini .rounded-pill {
  justify-self: start;
}

body[data-page="team"] .ndppc-team-page-mini .ndppc-home-team-mini-copy {
  height: 100%;
  align-content: start;
}

body[data-page="team"] .ndppc-team-page-mini .ndppc-home-team-mini-copy p {
  color: var(--ndppc-copy);
}

body[data-page="team"] .ndppc-team-page-mini .ndppc-card-actions {
  margin-top: auto;
  padding-top: 0.1rem;
}

body[data-page="team"] .ndppc-team-page-mini-associate {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 237, 222, 0.94));
}

body[data-page="team"] .ndppc-team-page-mini-scholar {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(241, 246, 243, 0.94));
}

body[data-page="team"] .ndppc-team-page-empty {
  margin-top: 0.3rem;
}

@media (max-width: 1199px) {
  body[data-page="team"] .ndppc-team-directory-meta {
    min-width: 116px;
    min-height: 108px;
  }

  body[data-page="team"] .ndppc-team-band-head strong {
    min-width: 56px;
    min-height: 56px;
    font-size: 1.3rem;
  }

  body[data-page="team"] .ndppc-team-page-roster,
  body[data-page="team"] .ndppc-team-page-roster-only {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body[data-page="team"] .ndppc-team-directory-overview-head {
    grid-template-columns: 1fr;
  }

  body[data-page="team"] .ndppc-team-directory-meta {
    justify-self: start;
    min-width: 0;
    width: fit-content;
    min-height: 0;
    grid-auto-flow: column;
    grid-template-columns: auto auto auto;
    align-items: center;
    gap: 0.55rem;
    padding: 0.7rem 0.9rem;
  }
}

@media (max-width: 767px) {
  body[data-page="team"] .ndppc-team-page-shell {
    padding-top: 0;
  }

  body[data-page="team"] .ndppc-team-banner-frame,
  body[data-page="team"] .ndppc-team-banner-frame img {
    min-height: 142px;
  }

  body[data-page="team"] .ndppc-team-page-head {
    padding-top: 0.95rem;
    padding-bottom: 0.95rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="team"] .ndppc-team-page-head h1 {
    font-size: 1.65rem;
  }

  body[data-page="team"] .ndppc-team-page-head p {
    line-height: 1.75;
  }

  body[data-page="team"] .ndppc-team-directory-overview {
    padding: 1rem;
  }

  body[data-page="team"] .ndppc-team-overview-stats {
    grid-template-columns: 1fr;
  }

  body[data-page="team"] .ndppc-team-directory-meta {
    width: 100%;
    justify-content: center;
  }

  body[data-page="team"] .ndppc-team-band-head {
    flex-direction: column;
    align-items: start;
  }

  body[data-page="team"] .ndppc-team-band-head strong {
    min-width: 52px;
    min-height: 52px;
    border-radius: 16px;
    font-size: 1.2rem;
  }

  body[data-page="team"] .ndppc-team-page-roster,
  body[data-page="team"] .ndppc-team-page-roster-only {
    grid-template-columns: 1fr;
  }

  body[data-page="team"] .ndppc-team-page-mini {
    grid-template-columns: 132px minmax(0, 1fr);
    gap: 0.9rem;
  }

  body[data-page="team"] .ndppc-team-page-mini .ndppc-home-team-mini-media {
    min-width: 132px;
  }

  body[data-page="team"] .ndppc-team-page-mini .ndppc-home-team-mini-media img {
    width: 132px;
    height: 154px;
    min-height: 154px;
    border-radius: 16px;
  }
}

body[data-page="about"] .ndppc-about-ux-hero {
  padding: 40px 0 34px;
  background:
    linear-gradient(180deg, rgba(20, 53, 38, 0.04), rgba(20, 53, 38, 0)),
    linear-gradient(135deg, rgba(184, 146, 66, 0.08), rgba(255, 255, 255, 0.65));
}

body[data-page="about"] .ndppc-about-ux-breadcrumb {
  margin-bottom: 1rem;
}

body[data-page="about"] .ndppc-about-ux-breadcrumb a {
  color: var(--ndppc-primary);
}

body[data-page="about"] .ndppc-about-ux-intro {
  display: grid;
  grid-template-columns: minmax(0, 0.98fr) minmax(360px, 1.02fr);
  gap: 1.5rem;
  align-items: stretch;
}

body[data-page="about"] .ndppc-about-ux-copy {
  display: grid;
  gap: 1rem;
  align-content: start;
}

body[data-page="about"] .ndppc-about-ux-badge {
  width: max-content;
  color: #6c521f;
  background: var(--ndppc-accent-soft) !important;
}

body[data-page="about"] .ndppc-about-ux-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(2.15rem, 3.2vw, 3.2rem);
  line-height: 1.08;
}

body[data-page="about"] .ndppc-about-ux-copy .ndppc-card-copy {
  margin: 0;
  text-align: justify;
}

body[data-page="about"] .ndppc-about-ux-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

body[data-page="about"] .ndppc-about-ux-actions .btn {
  min-height: 44px;
  padding: 0.62rem 1rem;
  font-weight: 700;
}

body[data-page="about"] .ndppc-about-ux-keywords {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="about"] .ndppc-about-ux-keywords .badge {
  padding: 0.45rem 0.85rem;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--ndppc-primary-dark);
  background: rgba(255, 255, 255, 0.9) !important;
  border: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="about"] .ndppc-about-ux-carousel-shell {
  min-width: 0;
}

body[data-page="about"] .ndppc-about-ux-carousel {
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.1);
  box-shadow: 0 20px 42px rgba(20, 53, 38, 0.08);
  background: #fff;
}

body[data-page="about"] .ndppc-about-ux-carousel .carousel-item img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

body[data-page="about"] .ndppc-about-ux-carousel .carousel-caption {
  right: 1.2rem;
  bottom: 1.2rem;
  left: 1.2rem;
  padding: 1rem 1.1rem;
  border-radius: 16px;
  background: rgba(12, 30, 22, 0.72);
  text-align: left;
}

body[data-page="about"] .ndppc-about-ux-carousel .carousel-caption h3 {
  margin: 0.6rem 0 0.35rem;
  color: #fff;
  font-size: 1.35rem;
}

body[data-page="about"] .ndppc-about-ux-carousel .carousel-caption p {
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
}

body[data-page="about"] .ndppc-about-ux-stat-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.4rem;
}

body[data-page="about"] .ndppc-about-ux-stat-card {
  border: 1px solid var(--ndppc-line);
  border-radius: 18px;
  box-shadow: none;
}

body[data-page="about"] .ndppc-about-ux-stat-card .card-body,
body[data-page="about"] .ndppc-about-ux-card .card-body {
  display: grid;
  gap: 0.85rem;
  align-content: start;
}

body[data-page="about"] .ndppc-about-ux-stat-card .ndppc-count {
  font-size: clamp(1.95rem, 2.7vw, 2.65rem);
  color: var(--ndppc-primary-dark);
  line-height: 1;
}

body[data-page="about"] .ndppc-about-ux-stat-card h3,
body[data-page="about"] .ndppc-about-ux-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.24rem;
}

body[data-page="about"] .ndppc-about-ux-stat-card p,
body[data-page="about"] .ndppc-about-ux-card p,
body[data-page="about"] .ndppc-about-ux-list .list-group-item span {
  color: var(--ndppc-copy-soft);
}

body[data-page="about"] .ndppc-about-ux-tabs .nav-tabs {
  gap: 0.6rem;
  border-bottom: 0;
  margin-bottom: 1.25rem;
}

body[data-page="about"] .ndppc-about-ux-tabs .nav-tabs .nav-link {
  border: 1px solid rgba(20, 53, 38, 0.1);
  border-radius: 999px;
  background: #fff;
  color: var(--ndppc-primary-dark);
  font-weight: 700;
}

body[data-page="about"] .ndppc-about-ux-tabs .nav-tabs .nav-link.active {
  background: var(--ndppc-primary);
  border-color: var(--ndppc-primary);
  color: #fff;
}

body[data-page="about"] .ndppc-about-ux-card {
  height: 100%;
  border: 1px solid var(--ndppc-line);
  border-radius: 18px;
  box-shadow: none;
  overflow: hidden;
}

body[data-page="about"] .ndppc-about-ux-card .card-img-top {
  aspect-ratio: 16 / 10;
  object-fit: cover;
}

body[data-page="about"] .ndppc-about-ux-list {
  gap: 0.65rem;
}

body[data-page="about"] .ndppc-about-ux-list .list-group-item {
  display: grid;
  gap: 0.2rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  border-radius: 14px !important;
  padding: 0.9rem 1rem;
}

body[data-page="about"] .ndppc-about-ux-list .list-group-item strong {
  color: var(--ndppc-primary-dark);
}

body[data-page="about"] .ndppc-about-ux-accordion .accordion-item {
  border-radius: 16px !important;
  overflow: hidden;
}

body[data-page="about"] .ndppc-about-ux-accordion .accordion-item + .accordion-item {
  margin-top: 0.9rem;
}

body[data-page="about"] .ndppc-about-ux-accordion .accordion-button {
  font-weight: 700;
}

@media (max-width: 1199px) {
  body[data-page="about"] .ndppc-about-ux-intro,
  body[data-page="about"] .ndppc-about-ux-stat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="about"] .ndppc-about-ux-intro {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="about"] .ndppc-about-ux-hero {
    padding: 28px 0 26px;
  }

  body[data-page="about"] .ndppc-about-ux-copy h1 {
    font-size: 1.95rem;
  }

  body[data-page="about"] .ndppc-about-ux-stat-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="about"] .ndppc-about-ux-tabs .nav-tabs {
    display: grid;
    grid-template-columns: 1fr;
  }

  body[data-page="about"] .ndppc-about-ux-carousel .carousel-caption {
    right: 0.8rem;
    bottom: 0.8rem;
    left: 0.8rem;
    padding: 0.8rem 0.9rem;
  }

  body[data-page="about"] .ndppc-about-ux-carousel .carousel-caption h3 {
    font-size: 1.1rem;
  }
}

body[data-page="infra"] .ndppc-infra-command-band,
body[data-page="infra"] .ndppc-infra-system-band,
body[data-page="infra"] .ndppc-infra-sensor-board-band,
body[data-page="infra"] .ndppc-infra-browser-band {
  padding-top: 22px;
  padding-bottom: 18px;
}

body[data-page="infra"] .ndppc-infra-command-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
  gap: 1.4rem;
  align-items: start;
}

body[data-page="infra"] .ndppc-infra-command-copy {
  display: grid;
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-command-copy h2,
body[data-page="infra"] .ndppc-infra-band-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.62rem, 2.05vw, 2.18rem);
  line-height: 1.08;
}

body[data-page="infra"] .ndppc-infra-command-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-band-head .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-system-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-sensor-tile-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-stage-text .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-command-note .ndppc-card-copy {
  text-align: justify;
}

body[data-page="infra"] .ndppc-infra-keyline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infra"] .ndppc-infra-keyline span {
  padding: 0.54rem 0.78rem;
  border-top: 2px solid rgba(139, 100, 20, 0.55);
  background: rgba(248, 244, 236, 0.92);
  color: var(--ndppc-primary-dark);
  font-size: 0.83rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}

body[data-page="infra"] .ndppc-infra-command-rail {
  display: grid;
  gap: 0.95rem;
  align-content: start;
  padding: 1rem;
  border-top: 4px solid rgba(139, 100, 20, 0.72);
  background: linear-gradient(180deg, rgba(248, 244, 236, 0.96), rgba(255, 255, 255, 0.96));
}

body[data-page="infra"] .ndppc-infra-command-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.82rem;
}

body[data-page="infra"] .ndppc-infra-command-stat {
  display: grid;
  gap: 0.34rem;
  padding: 0.88rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.9);
}

body[data-page="infra"] .ndppc-infra-command-stat strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.44rem;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-command-stat h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 0.97rem;
  line-height: 1.35;
}

body[data-page="infra"] .ndppc-infra-command-stat .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-command-note .ndppc-card-copy {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
}

body[data-page="infra"] .ndppc-infra-command-note {
  display: grid;
  gap: 0.45rem;
  padding-top: 0.2rem;
  border-top: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="infra"] .ndppc-infra-command-note span,
body[data-page="infra"] .ndppc-infra-browser-group {
  color: #8b6414;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body[data-page="infra"] .ndppc-infra-band-head {
  display: grid;
  gap: 0.8rem;
  max-width: 920px;
  margin-bottom: 1.3rem;
}

body[data-page="infra"] .ndppc-infra-system-grid {
  display: grid;
  gap: 1.2rem;
}

body[data-page="infra"] .ndppc-infra-system-card {
  display: grid;
  grid-template-columns: minmax(280px, 0.92fr) minmax(0, 1.08fr);
  gap: 1rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-system-card.is-reverse {
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
}

body[data-page="infra"] .ndppc-infra-system-card.is-reverse .ndppc-infra-system-media {
  order: 2;
}

body[data-page="infra"] .ndppc-infra-system-card.is-reverse .ndppc-infra-system-copy {
  order: 1;
}

body[data-page="infra"] .ndppc-infra-system-media {
  margin: 0;
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: #edf2eb;
}

body[data-page="infra"] .ndppc-infra-system-media img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  aspect-ratio: 5 / 4;
  object-fit: cover;
}

body[data-page="infra"] .ndppc-infra-system-copy {
  display: grid;
  gap: 0.82rem;
  align-content: start;
  padding: 1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.96);
}

body[data-page="infra"] .ndppc-infra-system-copy h3,
body[data-page="infra"] .ndppc-infra-sensor-tile-copy h3,
body[data-page="infra"] .ndppc-infra-stage-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.18rem;
  line-height: 1.28;
}

body[data-page="infra"] .ndppc-infra-system-points,
body[data-page="infra"] .ndppc-infra-sensor-points,
body[data-page="infra"] .ndppc-infra-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.62rem;
}

body[data-page="infra"] .ndppc-infra-sensor-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-sensor-tile {
  display: grid;
  gap: 0.8rem;
  padding: 1rem;
  border-top: 4px solid rgba(20, 53, 38, 0.88);
  background: rgba(255, 255, 255, 0.96);
}

body[data-page="infra"] .ndppc-infra-sensor-tile.is-wide {
  grid-column: span 2;
}

body[data-page="infra"] .ndppc-infra-sensor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

body[data-page="infra"] .ndppc-infra-sensor-head .rounded-pill {
  padding: 0.35rem 0.56rem;
  font-size: 0.64rem;
}

body[data-page="infra"] .ndppc-infra-sensor-index {
  color: rgba(20, 53, 38, 0.22);
  font-size: 1.72rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-sensor-tile-copy {
  display: grid;
  gap: 0.58rem;
}

body[data-page="infra"] .ndppc-infra-browser-shell {
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 1.1rem;
  align-items: start;
  padding: 1.1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 243, 232, 0.82));
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.62rem;
  padding: 0;
  border: 0;
  background: transparent;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  min-height: 50px;
  padding: 0.82rem 0.9rem;
  justify-content: flex-start;
  border-color: rgba(20, 53, 38, 0.14);
  background: rgba(255, 255, 255, 0.96);
  text-align: left;
  line-height: 1.35;
  white-space: normal;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active {
  border-color: rgba(20, 53, 38, 0.96);
  background: var(--ndppc-primary-dark);
  color: #fff;
}

body[data-page="infra"] .ndppc-infra-browser-detail {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-page="infra"] .ndppc-infra-stage-panel {
  display: grid;
  grid-template-columns: minmax(300px, 0.94fr) minmax(0, 1.06fr);
  gap: 1rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-stage-media {
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: #edf2eb;
}

body[data-page="infra"] .ndppc-infra-stage-media img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  aspect-ratio: 5 / 4;
  object-fit: cover;
}

body[data-page="infra"] .ndppc-infra-stage-copy {
  display: grid;
  gap: 0.82rem;
  align-content: start;
  padding: 1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.94);
}

body[data-page="infra"] .ndppc-infra-stage-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
}

body[data-page="infra"] .ndppc-infra-stage-kicker {
  color: #8b6414;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body[data-page="infra"] .ndppc-infra-stage-text {
  display: grid;
  gap: 0.68rem;
}

body[data-page="infra"] .ndppc-infra-stage-points-wrap {
  display: grid;
  gap: 0.6rem;
}

body[data-page="infra"] .ndppc-infra-stage-points-wrap strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

@media (max-width: 1199px) {
  body[data-page="infra"] .ndppc-infra-command-grid,
  body[data-page="infra"] .ndppc-infra-system-card,
  body[data-page="infra"] .ndppc-infra-system-card.is-reverse,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-stage-panel {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-system-card.is-reverse .ndppc-infra-system-media,
  body[data-page="infra"] .ndppc-infra-system-card.is-reverse .ndppc-infra-system-copy {
    order: initial;
  }
}

@media (max-width: 767px) {
  body[data-page="infra"] .ndppc-infra-command-band,
  body[data-page="infra"] .ndppc-infra-system-band,
  body[data-page="infra"] .ndppc-infra-sensor-board-band,
  body[data-page="infra"] .ndppc-infra-browser-band {
    padding-top: 18px;
    padding-bottom: 12px;
  }

  body[data-page="infra"] .ndppc-infra-command-copy h2,
  body[data-page="infra"] .ndppc-infra-band-head h2 {
    font-size: 1.66rem;
  }

  body[data-page="infra"] .ndppc-infra-command-stats,
  body[data-page="infra"] .ndppc-infra-sensor-board {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-sensor-tile.is-wide {
    grid-column: auto;
  }

  body[data-page="infra"] .ndppc-infra-command-rail,
  body[data-page="infra"] .ndppc-infra-system-copy,
  body[data-page="infra"] .ndppc-infra-sensor-tile,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-stage-copy {
    padding: 0.95rem;
  }

  body[data-page="infra"] .ndppc-infra-sensor-head {
    align-items: flex-start;
  }

  body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
    min-height: 48px;
  }
}

body[data-page="infra"] .banner.ndppc-infra-banner {
  padding: 0;
  margin-top: 0;
}

body[data-page="infra"] .banner.ndppc-infra-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="infra"] .banner.ndppc-infra-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="infra"] .banner_content.ndppc-infra-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="infra"] .ndppc-infra-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="infra"] .ndppc-infra-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="infra"] .ndppc-infra-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(248, 244, 236, 0.98) 0%, rgba(248, 244, 236, 0.95) 34%, rgba(248, 244, 236, 0.82) 58%, rgba(248, 244, 236, 0.56) 100%);
  z-index: 1;
}

body[data-page="infra"] .ndppc-infra-banner-copy {
  position: absolute;
  inset: 0;
  display: grid;
  gap: 1rem;
  width: 100%;
  max-width: none;
  margin: 0;
  align-content: center;
  padding-top: 1.35rem;
  padding-bottom: 1.35rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="infra"] .ndppc-infra-banner-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="infra"] .ndppc-infra-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="infra"] .ndppc-infra-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.05;
}

body[data-page="infra"] .ndppc-infra-intro-band,
body[data-page="infra"] .ndppc-infra-flow-band,
body[data-page="infra"] .ndppc-infra-sensor-band,
body[data-page="infra"] .ndppc-infra-browser-band {
  padding-top: 22px;
  padding-bottom: 18px;
}

body[data-page="infra"] .ndppc-infra-intro-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
  gap: 1.35rem;
  align-items: start;
}

body[data-page="infra"] .ndppc-infra-intro-copy {
  display: grid;
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-intro-copy h2,
body[data-page="infra"] .ndppc-infra-band-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.62rem, 2.05vw, 2.2rem);
  line-height: 1.08;
}

body[data-page="infra"] .ndppc-infra-intro-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-band-head .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-flow-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-sensor-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-stage-text .ndppc-card-copy {
  text-align: justify;
}

body[data-page="infra"] .ndppc-infra-keyline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infra"] .ndppc-infra-keyline span {
  padding: 0.52rem 0.78rem;
  border-top: 2px solid rgba(139, 100, 20, 0.55);
  background: rgba(248, 244, 236, 0.9);
  color: var(--ndppc-primary-dark);
  font-size: 0.83rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}

body[data-page="infra"] .ndppc-infra-intro-metrics {
  display: grid;
  gap: 0.9rem;
  align-content: start;
  padding: 1rem;
  border-top: 4px solid rgba(139, 100, 20, 0.72);
  background: linear-gradient(180deg, rgba(248, 244, 236, 0.96), rgba(255, 255, 255, 0.96));
}

body[data-page="infra"] .ndppc-infra-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.82rem;
}

body[data-page="infra"] .ndppc-infra-metric-card {
  display: grid;
  gap: 0.34rem;
  padding: 0.88rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.9);
}

body[data-page="infra"] .ndppc-infra-metric-card strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.44rem;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-metric-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 0.97rem;
  line-height: 1.35;
}

body[data-page="infra"] .ndppc-infra-metric-card .ndppc-card-copy {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  text-align: left;
}

body[data-page="infra"] .ndppc-infra-band-head {
  display: grid;
  gap: 0.8rem;
  max-width: 920px;
  margin-bottom: 1.3rem;
}

body[data-page="infra"] .ndppc-infra-flow-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-flow-card {
  display: grid;
  gap: 0.9rem;
  padding: 1.12rem 1rem;
  border-top: 4px solid rgba(20, 53, 38, 0.9);
  background: rgba(255, 255, 255, 0.96);
}

body[data-page="infra"] .ndppc-infra-flow-step {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

body[data-page="infra"] .ndppc-infra-flow-number {
  color: rgba(20, 53, 38, 0.26);
  font-size: 1.75rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-flow-step .material-symbols-outlined {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  background: rgba(243, 236, 218, 0.95);
  color: #8b6414;
  font-size: 1.5rem;
  font-variation-settings: "FILL" 1, "wght" 600, "opsz" 24;
}

body[data-page="infra"] .ndppc-infra-flow-copy {
  display: grid;
  gap: 0.72rem;
}

body[data-page="infra"] .ndppc-infra-flow-copy h3,
body[data-page="infra"] .ndppc-infra-sensor-copy h3,
body[data-page="infra"] .ndppc-infra-stage-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.18rem;
  line-height: 1.28;
}

body[data-page="infra"] .ndppc-infra-flow-list {
  margin: 0;
  padding-left: 1rem;
  color: var(--ndppc-copy);
}

body[data-page="infra"] .ndppc-infra-flow-list li + li {
  margin-top: 0.5rem;
}

body[data-page="infra"] .ndppc-infra-sensor-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.25rem;
}

body[data-page="infra"] .ndppc-infra-sensor-card {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 0.95rem;
  align-items: start;
  padding: 1rem 0;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
  background: transparent;
}

body[data-page="infra"] .ndppc-infra-sensor-card:nth-child(-n+2) {
  padding-top: 0;
  border-top: 0;
}

body[data-page="infra"] .ndppc-infra-sensor-head {
  display: grid;
  gap: 0.55rem;
  align-content: start;
}

body[data-page="infra"] .ndppc-infra-sensor-head .rounded-pill {
  padding: 0.35rem 0.55rem;
  font-size: 0.64rem;
}

body[data-page="infra"] .ndppc-infra-sensor-index {
  color: rgba(20, 53, 38, 0.22);
  font-size: 1.72rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-sensor-copy {
  display: grid;
  gap: 0.58rem;
}

body[data-page="infra"] .ndppc-infra-sensor-points,
body[data-page="infra"] .ndppc-infra-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.62rem;
}

body[data-page="infra"] .ndppc-infra-browser-shell {
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 1.1rem;
  align-items: start;
  padding: 1.1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 243, 232, 0.82));
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.62rem;
  padding: 0;
  border: 0;
  background: transparent;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  min-height: 50px;
  padding: 0.82rem 0.9rem;
  justify-content: flex-start;
  border-color: rgba(20, 53, 38, 0.14);
  background: rgba(255, 255, 255, 0.96);
  text-align: left;
  line-height: 1.35;
  white-space: normal;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active {
  border-color: rgba(20, 53, 38, 0.96);
  background: var(--ndppc-primary-dark);
  color: #fff;
}

body[data-page="infra"] .ndppc-infra-browser-detail {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-page="infra"] .ndppc-infra-stage-panel {
  display: grid;
  grid-template-columns: minmax(300px, 0.94fr) minmax(0, 1.06fr);
  gap: 1rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-stage-media {
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: #edf2eb;
}

body[data-page="infra"] .ndppc-infra-stage-media img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  aspect-ratio: 5 / 4;
  object-fit: cover;
}

body[data-page="infra"] .ndppc-infra-stage-copy {
  display: grid;
  gap: 0.82rem;
  align-content: start;
  padding: 1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.94);
}

body[data-page="infra"] .ndppc-infra-stage-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
}

body[data-page="infra"] .ndppc-infra-stage-kicker {
  color: #8b6414;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body[data-page="infra"] .ndppc-infra-stage-text {
  display: grid;
  gap: 0.68rem;
}

body[data-page="infra"] .ndppc-infra-stage-points-wrap {
  display: grid;
  gap: 0.6rem;
}

body[data-page="infra"] .ndppc-infra-stage-points-wrap strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.86rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

@media (max-width: 1199px) {
  body[data-page="infra"] .ndppc-infra-intro-grid,
  body[data-page="infra"] .ndppc-infra-flow-grid,
  body[data-page="infra"] .ndppc-infra-sensor-grid,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-stage-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991px) {
  body[data-page="infra"] .ndppc-infra-banner-frame,
  body[data-page="infra"] .ndppc-infra-banner-frame img {
    min-height: 102px;
  }
}

@media (max-width: 767px) {
  body[data-page="infra"] .ndppc-infra-banner-frame,
  body[data-page="infra"] .ndppc-infra-banner-frame img {
    min-height: 88px;
  }

  body[data-page="infra"] .ndppc-infra-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="infra"] .ndppc-infra-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="infra"] .ndppc-infra-intro-band,
  body[data-page="infra"] .ndppc-infra-flow-band,
  body[data-page="infra"] .ndppc-infra-sensor-band,
  body[data-page="infra"] .ndppc-infra-browser-band {
    padding-top: 18px;
    padding-bottom: 12px;
  }

  body[data-page="infra"] .ndppc-infra-intro-copy h2,
  body[data-page="infra"] .ndppc-infra-band-head h2 {
    font-size: 1.66rem;
  }

  body[data-page="infra"] .ndppc-infra-metric-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-intro-metrics,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-stage-copy {
    padding: 0.95rem;
  }

  body[data-page="infra"] .ndppc-infra-sensor-card {
    grid-template-columns: 1fr;
    gap: 0.72rem;
  }

  body[data-page="infra"] .ndppc-infra-sensor-card:nth-child(2) {
    padding-top: 1rem;
    border-top: 1px solid rgba(20, 53, 38, 0.1);
  }

  body[data-page="infra"] .ndppc-infra-sensor-head {
    grid-template-columns: auto auto;
    display: grid;
    align-items: center;
    justify-content: space-between;
  }

  body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
    min-height: 48px;
  }
}

body[data-page="infra"] .ndppc-infra-overview-shell {
  gap: 0;
}

body[data-page="infra"] .ndppc-infra-overview-grid {
  grid-template-columns: minmax(0, 0.95fr) minmax(360px, 1.05fr);
  gap: 1.6rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-overview-copy {
  gap: 1.05rem;
}

body[data-page="infra"] .ndppc-infra-overview-copy h2 {
  font-size: clamp(1.86rem, 2.4vw, 2.55rem);
  line-height: 1.06;
}

body[data-page="infra"] .ndppc-infra-keyline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infra"] .ndppc-infra-keyline span {
  padding: 0.55rem 0.82rem;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: rgba(255, 255, 255, 0.74);
  color: var(--ndppc-primary-dark);
  font-size: 0.84rem;
  font-weight: 700;
  letter-spacing: 0.03em;
}

body[data-page="infra"] .ndppc-infra-overview-side {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(260px, 0.92fr);
  gap: 1rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-visual-main {
  min-height: 100%;
}

body[data-page="infra"] .ndppc-infra-overview-glance {
  align-content: start;
  padding: 1rem;
}

body[data-page="infra"] .ndppc-infra-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

body[data-page="infra"] .ndppc-infra-metric-card {
  display: grid;
  gap: 0.28rem;
  padding: 0.8rem;
  border-top: 3px solid rgba(139, 100, 20, 0.65);
  background: rgba(255, 255, 255, 0.9);
}

body[data-page="infra"] .ndppc-infra-metric-card strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.45rem;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-metric-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 0.96rem;
  line-height: 1.35;
}

body[data-page="infra"] .ndppc-infra-metric-card .ndppc-card-copy {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  text-align: left;
}

body[data-page="infra"] .ndppc-infra-stack-grid {
  gap: 1.05rem;
}

body[data-page="infra"] .ndppc-infra-stack-card {
  padding: 1.15rem 1rem;
}

body[data-page="infra"] .ndppc-infra-sensor-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-sensor-card {
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 0.95rem;
  align-items: start;
  padding: 1rem 0;
  border: 0;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
  background: transparent;
}

body[data-page="infra"] .ndppc-infra-sensor-card:nth-child(-n+2) {
  padding-top: 0;
  border-top: 0;
}

body[data-page="infra"] .ndppc-infra-sensor-head {
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 0.55rem;
}

body[data-page="infra"] .ndppc-infra-sensor-head .rounded-pill {
  padding: 0.36rem 0.58rem;
  font-size: 0.66rem;
}

body[data-page="infra"] .ndppc-infra-sensor-index {
  font-size: 1.7rem;
}

body[data-page="infra"] .ndppc-infra-sensor-copy {
  gap: 0.58rem;
}

body[data-page="infra"] .ndppc-infra-browser-shell {
  grid-template-columns: 296px minmax(0, 1fr);
  gap: 1.15rem;
  align-items: start;
  padding: 1.1rem;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
  grid-template-columns: 1fr;
  gap: 0.62rem;
}

body[data-page="infra"] .ndppc-infra-browser-detail {
  padding: 0;
  border-top: 0;
}

body[data-page="infra"] .ndppc-infra-stage-panel {
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-stage-copy {
  padding: 1rem;
}

@media (max-width: 1199px) {
  body[data-page="infra"] .ndppc-infra-overview-grid,
  body[data-page="infra"] .ndppc-infra-overview-side,
  body[data-page="infra"] .ndppc-infra-stack-grid,
  body[data-page="infra"] .ndppc-infra-sensor-grid,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-stage-panel {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-metric-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  body[data-page="infra"] .ndppc-infra-overview-grid,
  body[data-page="infra"] .ndppc-infra-overview-side,
  body[data-page="infra"] .ndppc-infra-metric-grid,
  body[data-page="infra"] .ndppc-infra-stack-grid,
  body[data-page="infra"] .ndppc-infra-sensor-grid,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-stage-panel {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-overview-copy h2,
  body[data-page="infra"] .ndppc-infra-band-head h2 {
    font-size: 1.68rem;
  }

  body[data-page="infra"] .ndppc-infra-metric-card,
  body[data-page="infra"] .ndppc-infra-overview-glance,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-stage-copy {
    padding: 0.95rem;
  }

  body[data-page="infra"] .ndppc-infra-sensor-card {
    grid-template-columns: 1fr;
    gap: 0.7rem;
  }

  body[data-page="infra"] .ndppc-infra-sensor-card:nth-child(2) {
    padding-top: 1rem;
    border-top: 1px solid rgba(20, 53, 38, 0.1);
  }

  body[data-page="infra"] .ndppc-infra-sensor-head {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }

  body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
    min-height: 48px;
  }
}

body[data-page="infra"] .ndppc-infra-overview-band {
  padding-top: 26px;
  padding-bottom: 18px;
  background:
    linear-gradient(180deg, rgba(20, 53, 38, 0.04), rgba(20, 53, 38, 0)),
    linear-gradient(135deg, rgba(247, 243, 232, 0.92), rgba(255, 255, 255, 0.98));
}

body[data-page="infra"] .ndppc-infra-overview-shell {
  display: grid;
  gap: 1.3rem;
}

body[data-page="infra"] .ndppc-infra-overview-grid {
  max-width: 1320px;
  display: grid;
  grid-template-columns: minmax(0, 0.96fr) minmax(360px, 1.04fr);
  gap: 1.45rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-overview-copy {
  display: grid;
  align-content: start;
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-overview-copy h2 {
  margin: 0;
  max-width: none;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.92rem, 2.55vw, 2.8rem);
  line-height: 1.05;
}

body[data-page="infra"] .ndppc-infra-overview-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-band-head .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-stack-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-sensor-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-stage-text .ndppc-card-copy {
  text-align: justify;
}

body[data-page="infra"] .ndppc-infra-overview-visual {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(220px, 0.85fr);
  gap: 1rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-visual-main,
body[data-page="infra"] .ndppc-infra-visual-secondary {
  margin: 0;
  min-height: 100%;
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: #edf2eb;
}

body[data-page="infra"] .ndppc-infra-visual-main img,
body[data-page="infra"] .ndppc-infra-visual-secondary img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  object-fit: cover;
}

body[data-page="infra"] .ndppc-infra-visual-rail {
  display: grid;
  grid-template-rows: minmax(0, 0.95fr) auto;
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-overview-glance {
  display: grid;
  gap: 0.9rem;
  padding: 1.15rem 1.1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.82);
}

body[data-page="infra"] .ndppc-infra-glance-list {
  display: grid;
  gap: 0.75rem;
}

body[data-page="infra"] .ndppc-infra-glance-list article {
  display: grid;
  gap: 0.24rem;
  padding-top: 0.7rem;
  border-top: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="infra"] .ndppc-infra-glance-list article:first-child {
  padding-top: 0;
  border-top: 0;
}

body[data-page="infra"] .ndppc-infra-glance-list strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.45rem;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-glance-list span {
  color: var(--ndppc-copy);
  line-height: 1.65;
}

body[data-page="infra"] .ndppc-infra-signal-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  padding-top: 0.15rem;
}

body[data-page="infra"] .ndppc-infra-signal-row article {
  display: grid;
  gap: 0.28rem;
  padding-top: 0.95rem;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
}

body[data-page="infra"] .ndppc-infra-signal-row span {
  color: #8b6414;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body[data-page="infra"] .ndppc-infra-signal-row strong {
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.45;
}

body[data-page="infra"] .ndppc-infra-stack-band,
body[data-page="infra"] .ndppc-infra-sensor-band,
body[data-page="infra"] .ndppc-infra-browser-band {
  padding-top: 22px;
  padding-bottom: 18px;
}

body[data-page="infra"] .ndppc-infra-band-head {
  display: grid;
  gap: 0.85rem;
  max-width: 920px;
  margin-bottom: 1.35rem;
}

body[data-page="infra"] .ndppc-infra-band-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.62rem, 2.15vw, 2.3rem);
  line-height: 1.08;
}

body[data-page="infra"] .ndppc-infra-stack-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-stack-card {
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr);
  gap: 1rem;
  padding: 1.2rem 1.1rem;
  border-top: 4px solid rgba(139, 100, 20, 0.85);
  background: rgba(255, 255, 255, 0.94);
}

body[data-page="infra"] .ndppc-infra-stack-step {
  color: rgba(20, 53, 38, 0.16);
  font-size: 2.7rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-stack-copy {
  display: grid;
  gap: 0.7rem;
}

body[data-page="infra"] .ndppc-infra-stack-copy h3,
body[data-page="infra"] .ndppc-infra-sensor-copy h3,
body[data-page="infra"] .ndppc-infra-stage-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.2rem;
  line-height: 1.25;
}

body[data-page="infra"] .ndppc-infra-stack-list {
  margin: 0;
  padding-left: 1rem;
  color: var(--ndppc-copy);
}

body[data-page="infra"] .ndppc-infra-stack-list li + li {
  margin-top: 0.5rem;
}

body[data-page="infra"] .ndppc-infra-sensor-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-sensor-card {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  padding: 1.05rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.96);
}

body[data-page="infra"] .ndppc-infra-sensor-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
}

body[data-page="infra"] .ndppc-infra-sensor-index {
  color: rgba(20, 53, 38, 0.22);
  font-size: 1.45rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-sensor-media {
  display: flex;
  justify-content: flex-end;
  align-items: center;
}

body[data-page="infra"] .ndppc-infra-sensor-media img {
  max-width: 72px;
  max-height: 72px;
  object-fit: contain;
}

body[data-page="infra"] .ndppc-infra-sensor-copy {
  display: grid;
  gap: 0.7rem;
}

body[data-page="infra"] .ndppc-infra-core-points,
body[data-page="infra"] .ndppc-infra-sensor-points,
body[data-page="infra"] .ndppc-infra-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infra"] .ndppc-infra-browser-shell {
  display: grid;
  gap: 1rem;
  padding: 1.15rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 243, 232, 0.72));
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
  padding: 0;
  border: 0;
  background: transparent;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  min-height: 54px;
  padding: 0.8rem 0.95rem;
  justify-content: flex-start;
  border-color: rgba(20, 53, 38, 0.14);
  background: rgba(255, 255, 255, 0.96);
  text-align: left;
  line-height: 1.35;
  white-space: normal;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active {
  border-color: rgba(20, 53, 38, 0.96);
  background: var(--ndppc-primary-dark);
  color: #fff;
}

body[data-page="infra"] .ndppc-infra-browser-detail {
  padding: 1rem 0 0;
  border: 0;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
  background: transparent;
  box-shadow: none;
}

body[data-page="infra"] .ndppc-infra-stage-panel {
  display: grid;
  grid-template-columns: minmax(300px, 0.92fr) minmax(0, 1.08fr);
  gap: 1.15rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-stage-media {
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background: #edf2eb;
}

body[data-page="infra"] .ndppc-infra-stage-media img {
  width: 100%;
  height: 100%;
  min-height: 100%;
  aspect-ratio: 5 / 4;
  object-fit: cover;
}

body[data-page="infra"] .ndppc-infra-stage-copy {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  padding: 1.15rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.92);
}

body[data-page="infra"] .ndppc-infra-stage-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
}

body[data-page="infra"] .ndppc-infra-stage-kicker {
  color: #8b6414;
  font-size: 0.77rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

body[data-page="infra"] .ndppc-infra-stage-text {
  display: grid;
  gap: 0.7rem;
}

body[data-page="infra"] .ndppc-infra-stage-points-wrap {
  display: grid;
  gap: 0.65rem;
}

body[data-page="infra"] .ndppc-infra-stage-points-wrap strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

@media (max-width: 1199px) {
  body[data-page="infra"] .ndppc-infra-overview-grid,
  body[data-page="infra"] .ndppc-infra-overview-visual,
  body[data-page="infra"] .ndppc-infra-stack-grid,
  body[data-page="infra"] .ndppc-infra-sensor-grid,
  body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav,
  body[data-page="infra"] .ndppc-infra-stage-panel {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-visual-rail {
    grid-template-columns: 1fr 1fr;
    grid-template-rows: none;
  }

  body[data-page="infra"] .ndppc-infra-signal-row {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="infra"] .ndppc-infra-overview-band,
  body[data-page="infra"] .ndppc-infra-stack-band,
  body[data-page="infra"] .ndppc-infra-sensor-band,
  body[data-page="infra"] .ndppc-infra-browser-band {
    padding-top: 18px;
    padding-bottom: 12px;
  }

  body[data-page="infra"] .ndppc-infra-overview-copy h2,
  body[data-page="infra"] .ndppc-infra-band-head h2 {
    font-size: 1.72rem;
  }

  body[data-page="infra"] .ndppc-infra-overview-visual,
  body[data-page="infra"] .ndppc-infra-visual-rail {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-overview-glance,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-stage-copy,
  body[data-page="infra"] .ndppc-infra-stack-card,
  body[data-page="infra"] .ndppc-infra-sensor-card {
    padding: 1rem;
  }

  body[data-page="infra"] .ndppc-infra-stack-card {
    grid-template-columns: 64px minmax(0, 1fr);
  }

  body[data-page="infra"] .ndppc-infra-stack-step {
    font-size: 2.2rem;
  }

  body[data-page="infra"] .ndppc-infra-sensor-head {
    align-items: flex-start;
  }

  body[data-page="infra"] .ndppc-infra-sensor-media {
    justify-content: flex-start;
  }

  body[data-page="infra"] .ndppc-infra-sensor-media img {
    max-width: 64px;
    max-height: 64px;
  }

  body[data-page="infra"] .ndppc-infra-stage-meta {
    justify-content: flex-start;
  }
}

/* Final Facility Systems Redesign Override */
body[data-page="infra"] .ndppc-infra-facility-band,
body[data-page="infra"] .ndppc-infra-ops-band,
body[data-page="infra"] .ndppc-infra-capability-band,
body[data-page="infra"] .ndppc-infra-browser-band-refresh {
  padding: 44px 0;
}

body[data-page="infra"] .ndppc-infra-facility-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.03fr) minmax(320px, 0.97fr);
  gap: 1.6rem;
  align-items: stretch;
}

body[data-page="infra"] .ndppc-infra-facility-copy,
body[data-page="infra"] .ndppc-infra-browser-intro,
body[data-page="infra"] .ndppc-infra-metric-card,
body[data-page="infra"] .ndppc-infra-ops-card,
body[data-page="infra"] .ndppc-infra-capability-card,
body[data-page="infra"] .ndppc-infra-browser-shell,
body[data-page="infra"] .ndppc-infra-browser-detail {
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 18px 34px rgba(20, 53, 38, 0.08);
}

body[data-page="infra"] .ndppc-infra-facility-copy {
  padding: 1.55rem 1.6rem;
  border-radius: 24px;
}

body[data-page="infra"] .ndppc-infra-facility-copy h2,
body[data-page="infra"] .ndppc-infra-section-head h2 {
  margin: 0 0 1rem;
  font-size: clamp(1.6rem, 2.15vw, 2.2rem);
  line-height: 1.14;
  color: var(--ndppc-primary-dark);
}

body[data-page="infra"] .ndppc-infra-facility-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-section-head .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-ops-copy .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-capability-card .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-browser-intro .ndppc-card-copy,
body[data-page="infra"] .ndppc-infra-stage-text .ndppc-card-copy {
  color: var(--ndppc-copy);
  line-height: 1.78;
}

body[data-page="infra"] .ndppc-infra-keyline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  margin: 1.25rem 0 1.35rem;
}

body[data-page="infra"] .ndppc-infra-keyline span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.5rem 0.95rem;
  border-radius: 999px;
  background: var(--ndppc-accent-soft);
  color: #7a5a21;
  font-size: 0.92rem;
  font-weight: 700;
}

body[data-page="infra"] .ndppc-infra-facility-visual {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(220px, 0.72fr);
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-facility-main,
body[data-page="infra"] .ndppc-infra-facility-secondary {
  margin: 0;
  border-radius: 24px;
  overflow: hidden;
  min-height: 100%;
}

body[data-page="infra"] .ndppc-infra-facility-main img,
body[data-page="infra"] .ndppc-infra-facility-secondary img {
  width: 100%;
  height: 100%;
  min-height: 240px;
  object-fit: cover;
  display: block;
}

body[data-page="infra"] .ndppc-infra-facility-rail {
  display: grid;
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="infra"] .ndppc-infra-metric-card {
  padding: 1rem 1rem 0.95rem;
  border-radius: 20px;
}

body[data-page="infra"] .ndppc-infra-metric-card strong {
  display: block;
  margin-bottom: 0.3rem;
  font-size: 2rem;
  line-height: 1;
  color: var(--ndppc-primary-dark);
}

body[data-page="infra"] .ndppc-infra-metric-card h3 {
  margin: 0 0 0.45rem;
  font-size: 0.98rem;
  color: #7a5a21;
}

body[data-page="infra"] .ndppc-infra-section-head {
  margin-bottom: 1.25rem;
  max-width: 76ch;
}

body[data-page="infra"] .ndppc-infra-ops-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-ops-card {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 1rem;
  padding: 1.2rem;
  border-radius: 22px;
}

body[data-page="infra"] .ndppc-infra-ops-step {
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

body[data-page="infra"] .ndppc-infra-ops-number {
  width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: linear-gradient(180deg, #173d2e 0%, #214b39 100%);
  color: #fff;
  font-size: 1.2rem;
  font-weight: 800;
}

body[data-page="infra"] .ndppc-infra-ops-copy h3,
body[data-page="infra"] .ndppc-infra-capability-card h3,
body[data-page="infra"] .ndppc-infra-stage-copy h3 {
  margin: 0 0 0.6rem;
  font-size: 1.2rem;
  line-height: 1.25;
  color: var(--ndppc-primary-dark);
}

body[data-page="infra"] .ndppc-infra-ops-points,
body[data-page="infra"] .ndppc-infra-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.9rem;
}

body[data-page="infra"] .ndppc-infra-capability-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-capability-card {
  padding: 1.2rem 1.2rem 1.1rem;
  border-radius: 22px;
}

body[data-page="infra"] .ndppc-infra-capability-list {
  margin: 0.95rem 0 0;
  padding-left: 1.15rem;
  display: grid;
  gap: 0.42rem;
}

body[data-page="infra"] .ndppc-infra-capability-list li {
  color: var(--ndppc-copy);
  line-height: 1.52;
}

body[data-page="infra"] .ndppc-infra-browser-refresh-shell {
  display: grid;
  gap: 1rem;
}

body[data-page="infra"] .ndppc-infra-browser-intro {
  padding: 1rem 1.2rem;
  border-radius: 20px;
}

body[data-page="infra"] .ndppc-infra-browser-shell {
  display: grid;
  grid-template-columns: minmax(240px, 280px) minmax(0, 1fr);
  gap: 1rem;
  padding: 1rem;
  border-radius: 24px;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
  display: grid;
  gap: 0.8rem;
  align-content: start;
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  display: grid;
  gap: 0.3rem;
  justify-items: start;
  padding: 1rem 1rem 0.95rem;
  border-radius: 18px;
  text-align: left;
  background: rgba(255, 255, 255, 0.9);
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn strong {
  font-size: 0.98rem;
  line-height: 1.3;
  color: var(--ndppc-primary-dark);
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn span {
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--ndppc-copy-soft);
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active {
  background: linear-gradient(180deg, rgba(22, 61, 46, 0.98), rgba(30, 71, 55, 0.98));
  border-color: rgba(22, 61, 46, 0.98);
}

body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active strong,
body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active span {
  color: rgba(255, 255, 255, 0.95);
}

body[data-page="infra"] .ndppc-infra-browser-detail {
  padding: 0;
  border-radius: 22px;
  overflow: hidden;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-panel {
  display: grid;
  grid-template-columns: minmax(240px, 0.8fr) minmax(0, 1.2fr);
  min-height: 100%;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-media {
  min-height: 100%;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-media img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  display: block;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-copy {
  padding: 1.35rem 1.4rem 1.3rem;
  background: rgba(255, 255, 255, 0.98);
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
  margin-bottom: 0.8rem;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-kicker {
  color: #7a5a21;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-points-wrap {
  margin-top: 1rem;
}

body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-points-wrap strong {
  display: block;
  margin-bottom: 0.65rem;
  color: var(--ndppc-primary-dark);
  font-size: 0.92rem;
}

@media (max-width: 1199px) {
  body[data-page="infra"] .ndppc-infra-facility-grid,
  body[data-page="infra"] .ndppc-infra-facility-visual,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-panel {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  body[data-page="infra"] .ndppc-infra-facility-band,
  body[data-page="infra"] .ndppc-infra-ops-band,
  body[data-page="infra"] .ndppc-infra-capability-band,
  body[data-page="infra"] .ndppc-infra-browser-band-refresh {
    padding: 32px 0;
  }

  body[data-page="infra"] .ndppc-infra-ops-grid,
  body[data-page="infra"] .ndppc-infra-capability-grid,
  body[data-page="infra"] .ndppc-infra-metric-grid,
  body[data-page="infra"] .ndppc-infra-browser-shell .ndppc-stage-nav {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-facility-copy,
  body[data-page="infra"] .ndppc-infra-browser-intro,
  body[data-page="infra"] .ndppc-infra-metric-card,
  body[data-page="infra"] .ndppc-infra-ops-card,
  body[data-page="infra"] .ndppc-infra-capability-card,
  body[data-page="infra"] .ndppc-infra-browser-shell,
  body[data-page="infra"] .ndppc-infra-browser-detail,
  body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-copy {
    padding: 1rem;
  }

  body[data-page="infra"] .ndppc-infra-facility-copy h2,
  body[data-page="infra"] .ndppc-infra-section-head h2 {
    font-size: 1.58rem;
  }

  body[data-page="infra"] .ndppc-infra-ops-card {
    grid-template-columns: 60px minmax(0, 1fr);
  }

  body[data-page="infra"] .ndppc-infra-ops-number {
    width: 48px;
    height: 48px;
    border-radius: 15px;
    font-size: 1.05rem;
  }

  body[data-page="infra"] .ndppc-infra-facility-main img,
  body[data-page="infra"] .ndppc-infra-facility-secondary img,
  body[data-page="infra"] .ndppc-infra-browser-band-refresh .ndppc-infra-stage-media img {
    min-height: 220px;
  }
}

/* Final Publications Scholar-Based Top-10 Layout */
body[data-page="publications"] .ndppc-publications-overview-band .container,
body[data-page="publications"] .ndppc-publications-record-band .container,
body[data-page="publications"] .ndppc-publications-doc-band .container {
  max-width: 1320px;
}

body[data-page="publications"] .ndppc-publications-overview-band,
body[data-page="publications"] .ndppc-publications-record-band,
body[data-page="publications"] .ndppc-publications-doc-band {
  padding-top: 32px;
  padding-bottom: 32px;
}

body[data-page="publications"] .ndppc-publications-top-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
  gap: 1.35rem;
  align-items: start;
}

body[data-page="publications"] .ndppc-publications-top-copy {
  display: grid;
  gap: 1rem;
}

body[data-page="publications"] .ndppc-publications-top-copy h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
}

body[data-page="publications"] .ndppc-publications-top-copy .ndppc-card-copy,
body[data-page="publications"] .ndppc-publication-top-copy .ndppc-card-copy,
body[data-page="publications"] .ndppc-publications-method-note .ndppc-card-copy {
  margin: 0;
  line-height: 1.82;
  text-align: justify;
}

body[data-page="publications"] .ndppc-publications-top-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.95rem;
}

body[data-page="publications"] .ndppc-publications-top-stat {
  display: grid;
  gap: 0.35rem;
  align-content: center;
  min-height: 122px;
  padding: 1rem 1.05rem;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(139, 100, 20, 0.14);
  border-radius: 20px;
}

body[data-page="publications"] .ndppc-publications-top-stat strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.5rem, 2vw, 2.1rem);
  line-height: 1;
}

body[data-page="publications"] .ndppc-publications-top-stat span {
  color: var(--ndppc-copy);
  font-size: 0.92rem;
  font-weight: 700;
}

body[data-page="publications"] .ndppc-publications-top-list {
  display: grid;
  gap: 1rem;
}

body[data-page="publications"] .ndppc-publication-top-item {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr) 220px;
  gap: 1rem;
  align-items: stretch;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(15, 43, 30, 0.09);
  border-radius: 24px;
}

body[data-page="publications"] .ndppc-publication-top-rank {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 0.25rem;
  padding: 1rem 0.85rem;
  background: linear-gradient(180deg, rgba(15, 43, 30, 0.08), rgba(184, 146, 66, 0.08));
  border-radius: 18px;
}

body[data-page="publications"] .ndppc-publication-top-rank-kicker {
  color: #7a5a21;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="publications"] .ndppc-publication-top-rank strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.4vw, 2.4rem);
  line-height: 1;
}

body[data-page="publications"] .ndppc-publication-top-copy {
  display: grid;
  align-content: start;
  gap: 0.72rem;
}

body[data-page="publications"] .ndppc-publication-top-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: center;
}

body[data-page="publications"] .ndppc-publication-top-year {
  color: #6a6f63;
  font-weight: 700;
}

body[data-page="publications"] .ndppc-publication-top-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.1rem, 1.55vw, 1.45rem);
  line-height: 1.3;
}

body[data-page="publications"] .ndppc-publication-top-note {
  margin: 0;
  color: #596257;
  font-size: 0.94rem;
  line-height: 1.65;
}

body[data-page="publications"] .ndppc-publication-top-metrics {
  display: grid;
  gap: 0.8rem;
  align-content: start;
}

body[data-page="publications"] .ndppc-publication-metric {
  display: grid;
  gap: 0.22rem;
  padding: 0.8rem 0.9rem;
  background: #f8f5ec;
  border: 1px solid rgba(139, 100, 20, 0.12);
  border-radius: 16px;
}

body[data-page="publications"] .ndppc-publication-metric span {
  color: #7a5a21;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body[data-page="publications"] .ndppc-publication-metric strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.18rem;
  line-height: 1.1;
}

body[data-page="publications"] .ndppc-publication-top-metrics .ndppc-link-btn {
  width: 100%;
  justify-content: center;
}

body[data-page="publications"] .ndppc-publications-method-note {
  display: grid;
  gap: 0.95rem;
  padding: 1.15rem 1.2rem;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(15, 43, 30, 0.09);
  border-radius: 24px;
}

body[data-page="publications"] .ndppc-publications-method-note h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.3rem, 1.8vw, 1.7rem);
}

@media (max-width: 1199px) {
  body[data-page="publications"] .ndppc-publications-top-shell,
  body[data-page="publications"] .ndppc-publication-top-item {
    grid-template-columns: 1fr;
  }

  body[data-page="publications"] .ndppc-publication-top-rank {
    grid-auto-flow: column;
    justify-content: start;
    justify-items: start;
    align-items: center;
    padding: 0.85rem 1rem;
  }

  body[data-page="publications"] .ndppc-publication-top-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
  }
}

@media (max-width: 767px) {
  body[data-page="publications"] .ndppc-publications-overview-band,
  body[data-page="publications"] .ndppc-publications-record-band,
  body[data-page="publications"] .ndppc-publications-doc-band {
    padding-top: 28px;
    padding-bottom: 28px;
  }

  body[data-page="publications"] .ndppc-publications-top-stats,
  body[data-page="publications"] .ndppc-publication-top-metrics {
    grid-template-columns: 1fr;
  }

  body[data-page="publications"] .ndppc-publication-top-item,
  body[data-page="publications"] .ndppc-publications-method-note {
    padding: 0.95rem;
  }

  body[data-page="publications"] .ndppc-publication-top-copy h3,
  body[data-page="publications"] .ndppc-publications-top-copy h2 {
    font-size: 1.42rem;
  }
}

/* Full Phenomics Publications Page */
body[data-page="phenomics-publications"] .ndppc-full-publications-overview-band .container,
body[data-page="phenomics-publications"] .ndppc-full-publications-list-band .container {
  max-width: 1320px;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-overview-band,
body[data-page="phenomics-publications"] .ndppc-full-publications-list-band {
  padding-top: 32px;
  padding-bottom: 32px;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  gap: 1.35rem;
  align-items: start;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-overview-copy {
  display: grid;
  gap: 1rem;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-overview-copy h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
}

body[data-page="phenomics-publications"] .ndppc-full-publications-overview-copy .ndppc-card-copy,
body[data-page="phenomics-publications"] .ndppc-full-publication-copy .ndppc-card-copy {
  margin: 0;
  line-height: 1.82;
  text-align: justify;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.95rem;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-summary-card {
  display: grid;
  gap: 0.35rem;
  min-height: 122px;
  align-content: center;
  padding: 1rem 1.05rem;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(139, 100, 20, 0.14);
  border-radius: 20px;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-summary-card strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.5rem, 2vw, 2.1rem);
  line-height: 1;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-summary-card span {
  color: var(--ndppc-copy);
  font-size: 0.92rem;
  font-weight: 700;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-list {
  display: grid;
  gap: 1rem;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-item {
  display: grid;
  grid-template-columns: 96px minmax(0, 1fr) 220px;
  gap: 1rem;
  align-items: stretch;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(15, 43, 30, 0.09);
  border-radius: 24px;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-year {
  display: grid;
  align-content: start;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-year strong {
  display: inline-grid;
  place-items: center;
  min-height: 84px;
  padding: 0.8rem;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.35rem, 1.9vw, 1.95rem);
  background: linear-gradient(180deg, rgba(15, 43, 30, 0.08), rgba(184, 146, 66, 0.08));
  border-radius: 18px;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-copy {
  display: grid;
  gap: 0.72rem;
  align-content: start;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  align-items: center;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-theme {
  color: #7a5a21;
  font-size: 0.86rem;
  font-weight: 700;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.08rem, 1.45vw, 1.38rem);
  line-height: 1.32;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-authors {
  display: grid;
  gap: 0.22rem;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-authors p {
  margin: 0;
  color: #5b6358;
  font-size: 0.94rem;
  line-height: 1.6;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-authors strong {
  color: #7a5a21;
  font-weight: 800;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-actions {
  display: grid;
  gap: 0.8rem;
  align-content: start;
}

body[data-page="phenomics-publications"] .ndppc-full-publication-actions .ndppc-link-btn {
  width: 100%;
  justify-content: center;
}

@media (max-width: 1199px) {
  body[data-page="phenomics-publications"] .ndppc-full-publications-overview-grid,
  body[data-page="phenomics-publications"] .ndppc-full-publication-item {
    grid-template-columns: 1fr;
  }

  body[data-page="phenomics-publications"] .ndppc-full-publications-summary,
  body[data-page="phenomics-publications"] .ndppc-full-publication-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  body[data-page="phenomics-publications"] .ndppc-full-publications-overview-band,
  body[data-page="phenomics-publications"] .ndppc-full-publications-list-band {
    padding-top: 28px;
    padding-bottom: 28px;
  }

  body[data-page="phenomics-publications"] .ndppc-full-publications-summary,
  body[data-page="phenomics-publications"] .ndppc-full-publication-actions {
    grid-template-columns: 1fr;
  }

  body[data-page="phenomics-publications"] .ndppc-full-publication-item,
  body[data-page="phenomics-publications"] .ndppc-full-publications-summary-card {
    padding: 0.95rem;
  }

  body[data-page="phenomics-publications"] .ndppc-full-publication-copy h3,
  body[data-page="phenomics-publications"] .ndppc-full-publications-overview-copy h2 {
    font-size: 1.4rem;
  }
}

/* Final Rebuild: Phenomics Publications Directory */
body[data-page="phenomics-publications"] .banner.ndppc-phenomics-publications-banner {
  padding-top: 0;
  margin-top: 0;
  background: transparent;
}

body[data-page="phenomics-publications"] .banner.ndppc-phenomics-publications-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="phenomics-publications"] .banner_content.ndppc-phenomics-publications-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  overflow: hidden;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 26%, rgba(250, 247, 240, 0.78) 54%, rgba(15, 43, 30, 0.28) 100%),
    linear-gradient(180deg, rgba(15, 43, 30, 0.08), rgba(15, 43, 30, 0.18));
  z-index: 1;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-copy {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: grid;
  align-content: center;
  gap: 0.8rem;
  padding-top: 1.35rem;
  padding-bottom: 1.35rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-copy h1 {
  margin: 0;
  max-width: none;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.55rem, 2.1vw, 2.1rem);
  line-height: 1.06;
  white-space: nowrap;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-overview-band .container,
body[data-page="phenomics-publications"] .ndppc-phenomics-publications-tools-band .container,
body[data-page="phenomics-publications"] .ndppc-full-publications-list-band .container {
  max-width: 1320px;
}

body[data-page="phenomics-publications"] .ndppc-full-publications-overview-band,
body[data-page="phenomics-publications"] .ndppc-phenomics-publications-tools-band,
body[data-page="phenomics-publications"] .ndppc-full-publications-list-band {
  padding-top: 32px;
  padding-bottom: 32px;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 0.82fr);
  gap: 1.35rem;
  align-items: start;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-copy {
  display: grid;
  gap: 1rem;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-copy h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-copy .ndppc-card-copy,
body[data-page="phenomics-publications"] .ndppc-phenomics-publication-main .ndppc-card-copy {
  margin: 0;
  line-height: 1.84;
  text-align: justify;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.95rem;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-stat {
  display: grid;
  gap: 0.35rem;
  min-height: 122px;
  align-content: center;
  padding: 1rem 1.05rem;
  background: rgba(255, 255, 255, 0.94);
  border: 1px solid rgba(139, 100, 20, 0.14);
  border-radius: 20px;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-stat strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.4rem, 2vw, 2.05rem);
  line-height: 1.05;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-stat span {
  color: var(--ndppc-copy);
  font-size: 0.92rem;
  font-weight: 700;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-tools {
  display: grid;
  gap: 1rem;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-search {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  align-items: center;
  min-height: 58px;
  padding: 0 1rem;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(15, 43, 30, 0.09);
  border-radius: 20px;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-search .material-symbols-outlined {
  color: #7a5a21;
  font-size: 1.4rem;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-search input {
  width: 100%;
  border: 0;
  outline: 0;
  background: transparent;
  color: var(--ndppc-primary-dark);
  font-size: 0.98rem;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-filter-bar {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 1rem;
  align-items: start;
}

body[data-page="phenomics-publications"] .ndppc-filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

body[data-page="phenomics-publications"] .ndppc-filter-pills button {
  min-height: 42px;
  padding: 0.55rem 1rem;
  border: 1px solid rgba(15, 43, 30, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.92);
  color: var(--ndppc-primary-dark);
  font-size: 0.92rem;
  font-weight: 700;
}

body[data-page="phenomics-publications"] .ndppc-filter-pills button.active {
  background: var(--ndppc-primary);
  border-color: var(--ndppc-primary);
  color: #fff;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-visible {
  display: grid;
  gap: 0.22rem;
  align-content: center;
  justify-items: center;
  min-height: 82px;
  padding: 0.95rem 1rem;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(139, 100, 20, 0.14);
  border-radius: 20px;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-visible strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.8rem;
  line-height: 1;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-visible span {
  color: var(--ndppc-copy);
  font-size: 0.9rem;
  font-weight: 700;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-directory {
  display: grid;
  gap: 1.3rem;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-year-group {
  display: grid;
  gap: 0.9rem;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-year-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding-bottom: 0.35rem;
  border-bottom: 1px solid rgba(15, 43, 30, 0.08);
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-year-head h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.35rem, 1.8vw, 1.7rem);
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-year-head span {
  color: #7a5a21;
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-year-list {
  display: grid;
  gap: 1rem;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publication-item {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr) 190px;
  gap: 1rem;
  align-items: start;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(15, 43, 30, 0.09);
  border-radius: 24px;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publication-side {
  display: grid;
  gap: 0.7rem;
  align-content: start;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publication-theme {
  color: #7a5a21;
  font-size: 0.86rem;
  font-weight: 700;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publication-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publication-main {
  display: grid;
  gap: 0.72rem;
  align-content: start;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publication-main h4 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.06rem, 1.4vw, 1.34rem);
  line-height: 1.34;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publication-link {
  display: grid;
  align-content: start;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publication-link .ndppc-link-btn {
  width: 100%;
  justify-content: center;
}

body[data-page="phenomics-publications"] .ndppc-phenomics-publications-empty {
  padding: 1.2rem;
}

@media (max-width: 1199px) {
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-shell,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publication-item,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-filter-bar {
    grid-template-columns: 1fr;
  }

  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-frame,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-frame img {
    min-height: 102px;
    max-height: 102px;
  }
}

@media (max-width: 767px) {
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-frame,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-frame img {
    min-height: 88px;
    max-height: 88px;
  }

  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-copy {
    gap: 0.6rem;
    padding-top: 1rem;
    padding-bottom: 1rem;
  }

  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-banner-copy h1 {
    white-space: normal;
    font-size: 1.38rem;
  }

  body[data-page="phenomics-publications"] .ndppc-full-publications-overview-band,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-tools-band,
  body[data-page="phenomics-publications"] .ndppc-full-publications-list-band {
    padding-top: 28px;
    padding-bottom: 28px;
  }

  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-stats,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publication-metrics {
    grid-template-columns: 1fr;
  }

  body[data-page="phenomics-publications"] .ndppc-phenomics-publication-item,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-visible,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-stat {
    padding: 0.95rem;
  }

  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-copy h2,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publication-main h4,
  body[data-page="phenomics-publications"] .ndppc-phenomics-publications-year-head h3 {
    font-size: 1.38rem;
  }
}

/* Final Rebuild: Publications Showcase */
body[data-page="publications"] .ndppc-publications-overview-band .container,
body[data-page="publications"] .ndppc-publications-record-band .container,
body[data-page="publications"] .ndppc-publications-archive-band .container {
  max-width: 1320px;
}

body[data-page="publications"] .ndppc-publications-overview-band,
body[data-page="publications"] .ndppc-publications-record-band,
body[data-page="publications"] .ndppc-publications-archive-band {
  padding-top: 34px;
  padding-bottom: 34px;
}

body[data-page="publications"] .ndppc-publications-showcase {
  display: grid;
  grid-template-columns: minmax(0, 1.14fr) minmax(340px, 0.86fr);
  gap: 1.5rem;
  align-items: stretch;
}

body[data-page="publications"] .ndppc-publications-showcase-copy {
  display: grid;
  gap: 1rem;
  align-content: start;
}

body[data-page="publications"] .ndppc-publications-showcase-copy h2,
body[data-page="publications"] .ndppc-publications-archive-copy h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.58rem, 2.2vw, 2.32rem);
  line-height: 1.22;
}

body[data-page="publications"] .ndppc-publications-showcase-copy .ndppc-card-copy,
body[data-page="publications"] .ndppc-publications-featured .ndppc-card-copy,
body[data-page="publications"] .ndppc-publications-theme-card .ndppc-card-copy,
body[data-page="publications"] .ndppc-publications-ranking-copy .ndppc-card-copy,
body[data-page="publications"] .ndppc-publications-archive-copy .ndppc-card-copy,
body[data-page="publications"] .ndppc-publications-record-band .ndppc-section-copy p {
  margin: 0;
  text-align: justify;
  line-height: 1.78;
}

body[data-page="publications"] .ndppc-publications-showcase-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.95rem;
}

body[data-page="publications"] .ndppc-publications-showcase-stat {
  display: grid;
  gap: 0.38rem;
  align-content: center;
  min-height: 114px;
  padding: 1rem 1.05rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 239, 223, 0.95));
  border: 1px solid rgba(139, 100, 20, 0.12);
  border-radius: 20px;
}

body[data-page="publications"] .ndppc-publications-showcase-stat strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.45rem, 2vw, 2.2rem);
  line-height: 1;
}

body[data-page="publications"] .ndppc-publications-showcase-stat span {
  color: #5f6559;
  font-size: 0.9rem;
  font-weight: 700;
}

body[data-page="publications"] .ndppc-publications-featured {
  display: grid;
  gap: 0.95rem;
  align-content: start;
  padding: 1.25rem 1.3rem;
  background: linear-gradient(180deg, rgba(15, 43, 30, 0.98), rgba(27, 60, 45, 0.95));
  border-radius: 26px;
  border: 1px solid rgba(184, 146, 66, 0.18);
  box-shadow: 0 18px 42px rgba(15, 43, 30, 0.13);
}

body[data-page="publications"] .ndppc-publications-featured .rounded-pill {
  width: fit-content;
  background: rgba(243, 236, 218, 0.14);
  color: #f1dfaf;
  border: 1px solid rgba(243, 236, 218, 0.18);
}

body[data-page="publications"] .ndppc-publications-featured-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  align-items: center;
}

body[data-page="publications"] .ndppc-publications-featured-meta span {
  color: rgba(241, 234, 214, 0.88);
  font-size: 0.88rem;
  font-weight: 700;
}

body[data-page="publications"] .ndppc-publications-featured h3 {
  margin: 0;
  color: #ffffff;
  font-size: clamp(1.18rem, 1.75vw, 1.58rem);
  line-height: 1.32;
}

body[data-page="publications"] .ndppc-publications-featured .ndppc-card-copy {
  color: rgba(245, 242, 233, 0.9);
}

body[data-page="publications"] .ndppc-publications-featured-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.8rem;
}

body[data-page="publications"] .ndppc-publication-metric {
  display: grid;
  gap: 0.22rem;
  padding: 0.82rem 0.9rem;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(139, 100, 20, 0.12);
  border-radius: 16px;
}

body[data-page="publications"] .ndppc-publications-featured .ndppc-publication-metric {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(243, 236, 218, 0.14);
}

body[data-page="publications"] .ndppc-publication-metric span {
  color: #8b6414;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

body[data-page="publications"] .ndppc-publications-featured .ndppc-publication-metric span {
  color: #dbc47b;
}

body[data-page="publications"] .ndppc-publication-metric strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.15rem;
  line-height: 1.1;
}

body[data-page="publications"] .ndppc-publications-featured .ndppc-publication-metric strong {
  color: #ffffff;
}

body[data-page="publications"] .ndppc-publications-featured .ndppc-link-btn {
  width: fit-content;
}

body[data-page="publications"] .ndppc-publications-theme-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 1.2rem;
}

body[data-page="publications"] .ndppc-publications-theme-card {
  display: grid;
  gap: 0.68rem;
  align-content: start;
  min-height: 182px;
  padding: 1.05rem 1.1rem;
  background: rgba(255, 255, 255, 0.95);
  border: 1px solid rgba(15, 43, 30, 0.08);
  border-top: 4px solid rgba(139, 100, 20, 0.72);
  border-radius: 20px;
}

body[data-page="publications"] .ndppc-publications-theme-meta {
  color: #8b6414;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="publications"] .ndppc-publications-theme-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.12rem;
  line-height: 1.32;
}

body[data-page="publications"] .ndppc-publications-ranking-list {
  display: grid;
  gap: 1rem;
}

body[data-page="publications"] .ndppc-publications-ranking-item {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr) 238px;
  gap: 1rem;
  align-items: stretch;
  padding: 1rem;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(15, 43, 30, 0.08);
  border-radius: 24px;
}

body[data-page="publications"] .ndppc-publications-ranking-index {
  display: grid;
  gap: 0.25rem;
  align-content: center;
  justify-items: center;
  padding: 1rem 0.85rem;
  background: linear-gradient(180deg, rgba(15, 43, 30, 0.98), rgba(26, 69, 49, 0.95));
  border-radius: 18px;
}

body[data-page="publications"] .ndppc-publications-ranking-index-kicker {
  color: rgba(243, 236, 218, 0.84);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

body[data-page="publications"] .ndppc-publications-ranking-index strong {
  color: #ffffff;
  font-size: clamp(1.7rem, 2.4vw, 2.5rem);
  line-height: 1;
}

body[data-page="publications"] .ndppc-publications-ranking-copy {
  display: grid;
  gap: 0.72rem;
  align-content: start;
}

body[data-page="publications"] .ndppc-publications-ranking-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.62rem;
  align-items: center;
}

body[data-page="publications"] .ndppc-publications-ranking-year {
  color: #63695e;
  font-weight: 700;
}

body[data-page="publications"] .ndppc-publications-ranking-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.1rem, 1.55vw, 1.44rem);
  line-height: 1.31;
}

body[data-page="publications"] .ndppc-publications-ranking-note {
  margin: 0;
  color: #61685d;
  font-size: 0.92rem;
  line-height: 1.6;
}

body[data-page="publications"] .ndppc-publications-ranking-side {
  display: grid;
  gap: 0.8rem;
  align-content: start;
}

body[data-page="publications"] .ndppc-publications-ranking-side .ndppc-link-btn {
  width: 100%;
  justify-content: center;
}

body[data-page="publications"] .ndppc-publications-archive-band {
  padding-top: 10px;
}

body[data-page="publications"] .ndppc-publications-archive-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1.2rem;
  align-items: center;
  padding: 1.3rem 1.4rem;
  background: linear-gradient(135deg, rgba(15, 43, 30, 0.98), rgba(29, 71, 52, 0.95));
  border-radius: 26px;
  border: 1px solid rgba(184, 146, 66, 0.18);
}

body[data-page="publications"] .ndppc-publications-archive-copy .rounded-pill {
  width: fit-content;
  background: rgba(243, 236, 218, 0.14);
  color: #f1dfaf;
  border: 1px solid rgba(243, 236, 218, 0.18);
}

body[data-page="publications"] .ndppc-publications-archive-copy h2 {
  color: #ffffff;
}

body[data-page="publications"] .ndppc-publications-archive-copy {
  display: grid;
  gap: 0.85rem;
}

body[data-page="publications"] .ndppc-publications-archive-copy .ndppc-card-copy {
  color: rgba(245, 242, 233, 0.88);
}

body[data-page="publications"] .ndppc-publications-archive-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.8rem;
  justify-content: flex-end;
}

body[data-page="publications"] .ndppc-publications-archive-actions .ndppc-outline-btn {
  border-color: rgba(243, 236, 218, 0.3);
  color: #ffffff;
  background: transparent;
}

body[data-page="publications"] .ndppc-publications-archive-actions .ndppc-outline-btn:hover,
body[data-page="publications"] .ndppc-publications-archive-actions .ndppc-outline-btn:focus {
  background: rgba(243, 236, 218, 0.08);
  color: #ffffff;
}

@media (max-width: 1199px) {
  body[data-page="publications"] .ndppc-publications-showcase,
  body[data-page="publications"] .ndppc-publications-ranking-item,
  body[data-page="publications"] .ndppc-publications-archive-panel {
    grid-template-columns: 1fr;
  }

  body[data-page="publications"] .ndppc-publications-theme-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="publications"] .ndppc-publications-ranking-index {
    grid-auto-flow: column;
    justify-content: start;
    justify-items: start;
    align-items: center;
    padding: 0.88rem 1rem;
  }

  body[data-page="publications"] .ndppc-publications-ranking-side {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body[data-page="publications"] .ndppc-publications-archive-actions {
    justify-content: flex-start;
  }
}

@media (max-width: 767px) {
  body[data-page="publications"] .ndppc-publications-overview-band,
  body[data-page="publications"] .ndppc-publications-record-band,
  body[data-page="publications"] .ndppc-publications-archive-band {
    padding-top: 28px;
    padding-bottom: 28px;
  }

  body[data-page="publications"] .ndppc-publications-showcase-copy h2,
  body[data-page="publications"] .ndppc-publications-archive-copy h2,
  body[data-page="publications"] .ndppc-publications-record-band .ndppc-section-copy h3,
  body[data-page="publications"] .ndppc-publications-featured h3 {
    font-size: 1.42rem;
  }

  body[data-page="publications"] .ndppc-publications-showcase-stats,
  body[data-page="publications"] .ndppc-publications-theme-grid,
  body[data-page="publications"] .ndppc-publications-featured-metrics,
  body[data-page="publications"] .ndppc-publications-ranking-side {
    grid-template-columns: 1fr;
  }

  body[data-page="publications"] .ndppc-publications-showcase-stat,
  body[data-page="publications"] .ndppc-publications-theme-card,
  body[data-page="publications"] .ndppc-publications-ranking-item,
  body[data-page="publications"] .ndppc-publications-featured,
  body[data-page="publications"] .ndppc-publications-archive-panel {
    padding: 0.95rem;
  }

  body[data-page="publications"] .ndppc-publications-ranking-copy h3 {
    font-size: 1.08rem;
  }
}

/* Final Rebuild: Sensor Workflows Simplified */
body[data-page="infrastructure"] .ndppc-sensor-browser-band {
  padding-top: 26px;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-band .ndppc-sensor-section-head {
  max-width: none;
  margin-bottom: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell {
  grid-template-columns: 1fr;
  gap: 1.1rem;
  padding: 1.15rem;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(243, 238, 225, 0.78));
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
  align-content: stretch;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  min-height: 110px;
  padding: 0.95rem 1rem;
  align-content: start;
  border-radius: 20px;
  border-color: rgba(20, 53, 38, 0.12);
  background: rgba(255, 255, 255, 0.98);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn strong {
  font-size: 0.98rem;
  line-height: 1.28;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn span:last-child {
  font-size: 0.8rem;
  line-height: 1.4;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-detail {
  padding: 0;
  border-radius: 24px;
  overflow: hidden;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
  grid-template-columns: minmax(420px, 1.08fr) minmax(0, 0.92fr);
  min-height: 420px;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-media {
  padding: 1.4rem;
  background:
    radial-gradient(circle at top left, rgba(184, 146, 66, 0.18), transparent 34%),
    linear-gradient(180deg, #eef3ee 0%, #e5efe7 100%);
}

body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
  width: min(100%, 420px);
  max-height: 360px;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-copy {
  padding: 1.5rem 1.55rem 1.45rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-copy h3 {
  font-size: clamp(1.2rem, 1.7vw, 1.6rem);
}

body[data-page="infrastructure"] .ndppc-sensor-family-meta {
  color: #8b6414;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-family-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.15rem;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  gap: 0.55rem;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-button-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.55rem;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-button-head .rounded-pill {
  min-height: 26px;
  padding: 0.28rem 0.65rem;
  font-size: 0.76rem;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn strong {
  margin-top: 0.08rem;
}

body[data-page="infrastructure"] .ndppc-sensor-overview-copy .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-section-head .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-family-card .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-stage-text .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-stat-card .ndppc-card-copy {
  text-align: justify;
}

@media (max-width: 767px) {
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell {
    padding: 0.95rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
    min-height: 92px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media {
    padding: 1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
    width: min(100%, 260px);
    max-height: 220px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-browser-button-head {
    gap: 0.45rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-family-meta {
    font-size: 0.76rem;
  }
}

@media (max-width: 1199px) {
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
    grid-template-columns: minmax(320px, 0.98fr) minmax(0, 1.02fr);
    min-height: 360px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
    width: min(100%, 340px);
    max-height: 300px;
  }
}

@media (max-width: 767px) {
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
    width: min(100%, 260px);
    max-height: 220px;
  }
}

/* Final Rebuild: Sensor Workflow Showcase */
body[data-page="infrastructure"] .ndppc-sensor-browser-band {
  padding-top: 24px;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell {
  gap: 1.2rem;
  padding: 1.35rem;
  border-radius: 30px;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background:
    radial-gradient(circle at top left, rgba(184, 146, 66, 0.14), transparent 24%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(239, 233, 219, 0.86));
  box-shadow: 0 22px 42px rgba(20, 53, 38, 0.08);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(220px, 1fr);
  gap: 0.85rem;
  overflow-x: auto;
  padding-bottom: 0.2rem;
  scrollbar-width: none;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav::-webkit-scrollbar {
  display: none;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  min-height: 124px;
  padding: 1rem 1.05rem;
  border-radius: 22px;
  border-color: rgba(20, 53, 38, 0.12);
  background: rgba(255, 255, 255, 0.95);
  box-shadow: 0 10px 22px rgba(20, 53, 38, 0.05);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn:hover,
body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn:focus {
  transform: translateY(-2px);
  box-shadow: 0 16px 28px rgba(20, 53, 38, 0.09);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active {
  border-color: rgba(20, 53, 38, 0.96);
  background: linear-gradient(180deg, rgba(15, 43, 30, 0.98), rgba(27, 63, 45, 0.96));
  box-shadow: 0 18px 34px rgba(20, 53, 38, 0.16);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-detail {
  padding: 0;
  background: transparent;
  border: 0;
  overflow: visible;
  box-shadow: none;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
  grid-template-columns: 1fr;
  min-height: 540px;
  position: relative;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-media {
  min-height: 520px;
  padding: 0;
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    linear-gradient(145deg, rgba(20, 53, 38, 0.18), rgba(184, 146, 66, 0.1)),
    #e7efe8;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
  width: 100%;
  height: 100%;
  max-height: none;
  object-fit: cover;
  object-position: center center;
  filter: saturate(1.04) contrast(1.02);
}

body[data-page="infrastructure"] .ndppc-sensor-stage-copy {
  position: relative;
  z-index: 2;
  width: min(100%, 560px);
  margin: -170px 1.6rem 1.6rem auto;
  padding: 1.4rem 1.5rem 1.35rem;
  border-radius: 24px;
  border: 1px solid rgba(255, 255, 255, 0.52);
  background: rgba(255, 255, 255, 0.95);
  backdrop-filter: blur(10px);
  box-shadow: 0 20px 38px rgba(20, 53, 38, 0.12);
}

body[data-page="infrastructure"] .ndppc-sensor-stage-meta {
  justify-content: space-between;
  gap: 0.75rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-copy h3 {
  margin: 0 0 0.8rem;
  font-size: clamp(1.26rem, 1.8vw, 1.72rem);
  line-height: 1.24;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-text {
  gap: 0.76rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-points-wrap {
  margin-top: 1.05rem;
}

@media (max-width: 1199px) {
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
    grid-auto-columns: minmax(210px, 72%);
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
    min-height: 470px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media {
    min-height: 450px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-copy {
    width: min(100%, 500px);
    margin-top: -132px;
  }
}

@media (max-width: 767px) {
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell {
    padding: 0.95rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
    grid-auto-flow: row;
    grid-auto-columns: initial;
    grid-template-columns: 1fr;
    overflow: visible;
  }

  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
    min-height: 98px;
    box-shadow: none;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
    min-height: auto;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media {
    min-height: 280px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
    object-fit: contain;
    padding: 0.8rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-copy {
    width: auto;
    margin: 0.9rem 0 0;
    padding: 1rem;
  }
}

/* Final Rebuild: Sensor Workflow Spotlight */
body[data-page="infrastructure"] .ndppc-sensor-browser-shell {
  gap: 1.3rem;
  padding: 1.3rem;
  border-radius: 32px;
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.16), transparent 20%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(242, 236, 223, 0.9));
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
  grid-auto-columns: minmax(240px, 1fr);
  gap: 0.9rem;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
  min-height: 132px;
  padding: 1rem 1.05rem 0.95rem;
  border-radius: 24px;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 244, 235, 0.98));
  box-shadow: 0 12px 26px rgba(20, 53, 38, 0.06);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn.active {
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.2), transparent 40%),
    linear-gradient(180deg, rgba(15, 43, 30, 0.98), rgba(29, 68, 50, 0.96));
  box-shadow: 0 18px 34px rgba(20, 53, 38, 0.16);
}

body[data-page="infrastructure"] .ndppc-sensor-browser-button-head {
  justify-content: space-between;
  width: 100%;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
  display: grid;
  grid-template-columns: minmax(460px, 1.08fr) minmax(360px, 0.92fr);
  gap: 1.3rem;
  min-height: 540px;
  align-items: stretch;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-media {
  position: relative;
  min-height: 540px;
  padding: 2rem;
  border-radius: 30px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.38), transparent 16%),
    radial-gradient(circle at 82% 22%, rgba(184, 146, 66, 0.22), transparent 18%),
    linear-gradient(145deg, rgba(16, 49, 35, 0.94), rgba(47, 90, 67, 0.88));
}

body[data-page="infrastructure"] .ndppc-sensor-stage-watermark {
  position: absolute;
  left: 1.35rem;
  bottom: 1rem;
  color: rgba(255, 255, 255, 0.08);
  font-size: clamp(4.6rem, 9vw, 8.2rem);
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1;
  pointer-events: none;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-chip {
  position: absolute;
  top: 1.2rem;
  left: 1.2rem;
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.16);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
  position: relative;
  z-index: 1;
  width: min(100%, 470px);
  height: auto;
  max-height: 420px;
  margin: auto;
  object-fit: contain;
  filter: drop-shadow(0 18px 30px rgba(6, 21, 14, 0.34));
}

body[data-page="infrastructure"] .ndppc-sensor-stage-copy {
  position: static;
  width: auto;
  margin: 0;
  padding: 1.55rem 1.6rem 1.45rem;
  border-radius: 28px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.97);
  backdrop-filter: none;
  box-shadow: 0 20px 38px rgba(20, 53, 38, 0.09);
}

body[data-page="infrastructure"] .ndppc-sensor-stage-meta {
  justify-content: flex-start;
  gap: 0.6rem;
  margin-bottom: 0.85rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-code {
  min-width: 60px;
  min-height: 34px;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-copy .rounded-pill {
  background: var(--ndppc-accent-soft);
  color: #8b6414;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-copy h3 {
  margin: 0 0 0.75rem;
  font-size: clamp(1.3rem, 1.9vw, 1.84rem);
  line-height: 1.2;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-lead {
  margin: 0 0 0.95rem;
  color: var(--ndppc-primary-dark);
  font-size: 1.02rem;
  font-weight: 700;
  line-height: 1.72;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-text {
  display: grid;
  gap: 0.72rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-points-wrap {
  display: grid;
  gap: 0.75rem;
  margin-top: 1.1rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
}

body[data-page="infrastructure"] .ndppc-sensor-stage-points-wrap strong {
  margin-bottom: 0;
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

@media (max-width: 1199px) {
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
    grid-auto-columns: minmax(220px, 72%);
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-panel {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media {
    min-height: 420px;
  }
}

@media (max-width: 767px) {
  body[data-page="infrastructure"] .ndppc-sensor-browser-shell {
    padding: 0.95rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav {
    grid-auto-flow: row;
    grid-auto-columns: initial;
    grid-template-columns: 1fr;
    overflow: visible;
  }

  body[data-page="infrastructure"] .ndppc-sensor-browser-shell .ndppc-stage-nav .ndppc-outline-btn {
    min-height: 104px;
    box-shadow: none;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media {
    min-height: 300px;
    padding: 1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-media img {
    width: min(100%, 280px);
    max-height: 240px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-watermark {
    font-size: 4rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-copy {
    padding: 1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-stage-lead {
    font-size: 0.96rem;
  }
}

/* Final Rebuild: Sensors Page */
body[data-page="infrastructure"] .ndppc-sensor-overview-band,
body[data-page="infrastructure"] .ndppc-sensor-family-band,
body[data-page="infrastructure"] .ndppc-sensor-browser-band {
  padding-top: 34px;
  padding-bottom: 34px;
}

body[data-page="infrastructure"] .ndppc-sensor-overview-shell {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(360px, 0.95fr);
  gap: 1.45rem;
  align-items: stretch;
}

body[data-page="infrastructure"] .ndppc-sensor-overview-copy {
  padding: 1.55rem 1.65rem;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.14), transparent 26%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 240, 227, 0.92));
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 18px 36px rgba(20, 53, 38, 0.08);
}

body[data-page="infrastructure"] .ndppc-sensor-overview-copy h2,
body[data-page="infrastructure"] .ndppc-sensor-section-head h2 {
  margin: 0 0 1rem;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.58rem, 2.15vw, 2.24rem);
  line-height: 1.18;
}

body[data-page="infrastructure"] .ndppc-sensor-overview-copy .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-section-head .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-coverage-panel .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-family-card .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-spotlight-text .ndppc-card-copy {
  margin: 0;
  text-align: justify;
  line-height: 1.78;
}

body[data-page="infrastructure"] .ndppc-sensor-overview-side {
  display: grid;
  gap: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stat-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="infrastructure"] .ndppc-sensor-stat-card {
  padding: 1rem 1.05rem;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 16px 30px rgba(20, 53, 38, 0.07);
}

body[data-page="infrastructure"] .ndppc-sensor-stat-card strong {
  display: block;
  margin-bottom: 0.3rem;
  color: var(--ndppc-primary-dark);
  font-size: 2rem;
  line-height: 1;
}

body[data-page="infrastructure"] .ndppc-sensor-stat-card h3 {
  margin: 0 0 0.45rem;
  color: #8b6414;
  font-size: 0.96rem;
}

body[data-page="infrastructure"] .ndppc-sensor-coverage-panel {
  display: grid;
  gap: 0.85rem;
  padding: 1.15rem 1.2rem;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(15, 43, 30, 0.98), rgba(27, 64, 46, 0.96));
  border: 1px solid rgba(184, 146, 66, 0.16);
  box-shadow: 0 20px 36px rgba(20, 53, 38, 0.14);
}

body[data-page="infrastructure"] .ndppc-sensor-coverage-panel .rounded-pill {
  width: fit-content;
  background: rgba(243, 236, 218, 0.14);
  color: #f1dfaf;
  border: 1px solid rgba(243, 236, 218, 0.16);
}

body[data-page="infrastructure"] .ndppc-sensor-coverage-panel h3 {
  margin: 0;
  color: #ffffff;
  font-size: clamp(1.18rem, 1.6vw, 1.42rem);
}

body[data-page="infrastructure"] .ndppc-sensor-coverage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

body[data-page="infrastructure"] .ndppc-sensor-coverage-points .ndppc-pill {
  background: rgba(255, 255, 255, 0.12);
  color: rgba(255, 255, 255, 0.95);
  border-color: rgba(255, 255, 255, 0.12);
}

body[data-page="infrastructure"] .ndppc-sensor-family-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card {
  display: grid;
  gap: 0.78rem;
  align-content: start;
  min-height: 100%;
  padding: 1.25rem 1.25rem 1.15rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(20, 53, 38, 0.08);
  border-top: 4px solid rgba(139, 100, 20, 0.76);
  box-shadow: 0 18px 34px rgba(20, 53, 38, 0.08);
}

body[data-page="infrastructure"] .ndppc-sensor-family-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.22rem;
  line-height: 1.28;
}

body[data-page="infrastructure"] .ndppc-sensor-family-meta-row {
  display: grid;
  gap: 0.6rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-meta {
  color: #8b6414;
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-family-modules {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-modules span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.35rem 0.7rem;
  border-radius: 999px;
  background: rgba(20, 53, 38, 0.06);
  color: var(--ndppc-primary-dark);
  font-size: 0.82rem;
  font-weight: 700;
}

body[data-page="infrastructure"] .ndppc-sensor-family-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-shell {
  display: grid;
  gap: 1.2rem;
  padding: 1.3rem;
  border-radius: 32px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.16), transparent 22%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(242, 236, 223, 0.92));
  box-shadow: 0 24px 40px rgba(20, 53, 38, 0.08);
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-tab {
  display: grid;
  gap: 0.45rem;
  align-content: start;
  min-height: 134px;
  padding: 1rem 1.05rem;
  border-radius: 24px;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 244, 235, 0.98));
  box-shadow: 0 12px 24px rgba(20, 53, 38, 0.06);
  text-align: left;
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-tab-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-tab small {
  color: #8b6414;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-tab strong {
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.28;
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-note {
  color: var(--ndppc-copy-soft);
  font-size: 0.82rem;
  line-height: 1.42;
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-tab.active {
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.22), transparent 42%),
    linear-gradient(180deg, rgba(15, 43, 30, 0.98), rgba(27, 64, 46, 0.96));
  box-shadow: 0 18px 34px rgba(20, 53, 38, 0.16);
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-tab.active small,
body[data-page="infrastructure"] .ndppc-sensor-gallery-tab.active strong,
body[data-page="infrastructure"] .ndppc-sensor-gallery-tab.active .ndppc-sensor-gallery-note {
  color: rgba(255, 255, 255, 0.95);
}

body[data-page="infrastructure"] .ndppc-sensor-gallery-detail {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-stage {
  display: grid;
  grid-template-columns: minmax(460px, 1.08fr) minmax(360px, 0.92fr);
  gap: 1.3rem;
  align-items: stretch;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-media {
  position: relative;
  margin: 0;
  min-height: 540px;
  padding: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 30px;
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at 18% 18%, rgba(255, 255, 255, 0.38), transparent 16%),
    radial-gradient(circle at 82% 22%, rgba(184, 146, 66, 0.22), transparent 18%),
    linear-gradient(145deg, rgba(16, 49, 35, 0.94), rgba(47, 90, 67, 0.88));
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-code {
  position: absolute;
  left: 1.35rem;
  bottom: 1rem;
  color: rgba(255, 255, 255, 0.08);
  font-size: clamp(4.6rem, 9vw, 8.2rem);
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1;
  pointer-events: none;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-chip {
  position: absolute;
  top: 1.2rem;
  left: 1.2rem;
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.16);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-media img {
  position: relative;
  z-index: 1;
  width: min(100%, 470px);
  height: auto;
  max-height: 420px;
  object-fit: contain;
  filter: drop-shadow(0 18px 30px rgba(6, 21, 14, 0.34));
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-caption {
  position: absolute;
  left: 1.3rem;
  right: 1.3rem;
  bottom: 1.2rem;
  z-index: 2;
  display: grid;
  gap: 0.55rem;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-caption .rounded-pill {
  width: fit-content;
  background: rgba(255, 255, 255, 0.14);
  color: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(255, 255, 255, 0.16);
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-caption strong {
  color: #ffffff;
  font-size: clamp(1.25rem, 1.8vw, 1.8rem);
  line-height: 1.18;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-sidebar {
  display: grid;
  align-content: start;
  gap: 0.85rem;
  padding: 1.55rem 1.6rem 1.45rem;
  border-radius: 28px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.97);
  box-shadow: 0 20px 38px rgba(20, 53, 38, 0.09);
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-code {
  min-width: 60px;
  min-height: 34px;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-sidebar .rounded-pill {
  background: var(--ndppc-accent-soft);
  color: #8b6414;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-sidebar h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.3rem, 1.9vw, 1.84rem);
  line-height: 1.2;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-lead {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.72;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-text {
  display: grid;
  gap: 0.72rem;
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-outputs {
  display: grid;
  gap: 0.75rem;
  margin-top: 0.3rem;
  padding-top: 1rem;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
}

body[data-page="infrastructure"] .ndppc-sensor-spotlight-outputs strong {
  font-size: 0.82rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ndppc-primary-dark);
}

body[data-page="infrastructure"] .ndppc-sensor-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

@media (max-width: 1199px) {
  body[data-page="infrastructure"] .ndppc-sensor-overview-shell,
  body[data-page="infrastructure"] .ndppc-sensor-spotlight-stage {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-gallery-nav {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  body[data-page="infrastructure"] .ndppc-sensor-spotlight-media {
    min-height: 420px;
  }
}

@media (max-width: 767px) {
  body[data-page="infrastructure"] .ndppc-sensor-overview-band,
  body[data-page="infrastructure"] .ndppc-sensor-family-band,
  body[data-page="infrastructure"] .ndppc-sensor-browser-band {
    padding-top: 28px;
    padding-bottom: 28px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-overview-shell,
  body[data-page="infrastructure"] .ndppc-sensor-stat-grid,
  body[data-page="infrastructure"] .ndppc-sensor-family-grid,
  body[data-page="infrastructure"] .ndppc-sensor-gallery-nav,
  body[data-page="infrastructure"] .ndppc-sensor-spotlight-stage {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-overview-copy,
  body[data-page="infrastructure"] .ndppc-sensor-coverage-panel,
  body[data-page="infrastructure"] .ndppc-sensor-family-card,
  body[data-page="infrastructure"] .ndppc-sensor-gallery-shell,
  body[data-page="infrastructure"] .ndppc-sensor-spotlight-sidebar {
    padding: 1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-gallery-tab {
    min-height: 108px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-spotlight-media {
    min-height: 300px;
    padding: 1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-spotlight-media img {
    width: min(100%, 280px);
    max-height: 240px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-spotlight-code {
    font-size: 4rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-spotlight-caption {
    left: 1rem;
    right: 1rem;
    bottom: 1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-spotlight-sidebar h3,
  body[data-page="infrastructure"] .ndppc-sensor-overview-copy h2,
  body[data-page="infrastructure"] .ndppc-sensor-section-head h2 {
    font-size: 1.56rem;
  }

body[data-page="infrastructure"] .ndppc-sensor-spotlight-lead {
  font-size: 0.94rem;
}
}

/* Final Infra Page Redesign */
body[data-page="infra"] .ndppc-infra-glimpse-band {
  padding-top: 28px;
  padding-bottom: 12px;
}

body[data-page="infra"] .ndppc-infra-glimpse-shell {
  padding: 0;
  border: 0;
  background: transparent;
}

body[data-page="infra"] .ndppc-infra-glimpse-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.05rem;
}

body[data-page="infra"] .ndppc-infra-glimpse-stat {
  position: relative;
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 0.5rem;
  min-height: 158px;
  padding: 1.1rem 1rem 1rem;
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.18), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(246, 241, 230, 0.98));
  text-align: center;
}

body[data-page="infra"] .ndppc-infra-glimpse-stat::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 4px;
  background: rgba(139, 100, 20, 0.5);
}

body[data-page="infra"] .ndppc-infra-glimpse-stat strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.52rem, 2vw, 2.05rem);
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-glimpse-stat span:last-child {
  color: var(--ndppc-copy-soft);
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.35;
}

body[data-page="infra"] .ndppc-infra-glimpse-stat-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 58px;
  height: 58px;
  border-radius: 999px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(243, 236, 218, 0.96);
}

body[data-page="infra"] .ndppc-infra-glimpse-stat-icon i {
  color: #8b6414;
  font-size: 1.18rem;
}

body[data-page="infra"] .ndppc-infra-tone-green::after {
  background: rgba(34, 102, 67, 0.76);
}

body[data-page="infra"] .ndppc-infra-tone-bronze::after {
  background: rgba(139, 100, 20, 0.76);
}

body[data-page="infra"] .ndppc-infra-tone-aqua::after {
  background: rgba(34, 122, 130, 0.76);
}

body[data-page="infra"] .ndppc-infra-tone-slate::after {
  background: rgba(50, 80, 96, 0.76);
}

body[data-page="infra"] .ndppc-infra-tone-green .ndppc-infra-glimpse-stat-icon {
  background: rgba(223, 238, 229, 0.97);
}

body[data-page="infra"] .ndppc-infra-tone-green .ndppc-infra-glimpse-stat-icon i {
  color: #20583a;
}

body[data-page="infra"] .ndppc-infra-tone-bronze .ndppc-infra-glimpse-stat-icon {
  background: rgba(247, 238, 218, 0.97);
}

body[data-page="infra"] .ndppc-infra-tone-bronze .ndppc-infra-glimpse-stat-icon i {
  color: #8b6414;
}

body[data-page="infra"] .ndppc-infra-tone-aqua .ndppc-infra-glimpse-stat-icon {
  background: rgba(224, 240, 241, 0.97);
}

body[data-page="infra"] .ndppc-infra-tone-aqua .ndppc-infra-glimpse-stat-icon i {
  color: #2a7a82;
}

body[data-page="infra"] .ndppc-infra-tone-slate .ndppc-infra-glimpse-stat-icon {
  background: rgba(229, 236, 240, 0.97);
}

body[data-page="infra"] .ndppc-infra-tone-slate .ndppc-infra-glimpse-stat-icon i {
  color: #355366;
}

body[data-page="infra"] .ndppc-infra-showcase-band {
  padding-top: 26px;
  padding-bottom: 46px;
}

body[data-page="infra"] .ndppc-infra-showcase-stack {
  display: grid;
  gap: 2rem;
}

body[data-page="infra"] .ndppc-infra-showcase {
  display: grid;
  grid-template-columns: minmax(340px, 0.94fr) minmax(0, 1.06fr);
  align-items: stretch;
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 242, 232, 0.98));
}

body[data-page="infra"] .ndppc-infra-showcase-reverse {
  grid-template-columns: minmax(0, 1.06fr) minmax(340px, 0.94fr);
}

body[data-page="infra"] .ndppc-infra-showcase-reverse .ndppc-infra-showcase-media {
  order: 2;
}

body[data-page="infra"] .ndppc-infra-showcase-reverse .ndppc-infra-showcase-copy {
  order: 1;
}

body[data-page="infra"] .ndppc-infra-showcase-media {
  position: relative;
  margin: 0;
  min-height: 430px;
  background: #10281d;
}

body[data-page="infra"] .ndppc-infra-showcase-media-dual {
  display: grid;
  grid-template-rows: repeat(2, minmax(205px, 1fr));
  gap: 0.75rem;
  min-height: auto;
}

body[data-page="infra"] .ndppc-infra-showcase-media-screen {
  width: 100%;
  height: 100%;
}

body[data-page="infra"] .ndppc-infra-showcase-media-screen img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  display: block;
  object-fit: cover;
}

body[data-page="infra"] .ndppc-infra-showcase-media-dual .ndppc-infra-showcase-media-screen img {
  min-height: 205px;
}

body[data-page="infra"] .ndppc-infra-showcase-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7, 20, 14, 0.08), rgba(7, 20, 14, 0.4));
  pointer-events: none;
}

body[data-page="infra"] .ndppc-infra-showcase-media-badge {
  position: absolute;
  left: 1.1rem;
  bottom: 1.1rem;
  z-index: 1;
  display: inline-grid;
  gap: 0.18rem;
  min-width: 156px;
  padding: 0.85rem 0.95rem;
  background: rgba(255, 255, 255, 0.92);
}

body[data-page="infra"] .ndppc-infra-showcase-media-badge strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.6rem;
  line-height: 1;
}

body[data-page="infra"] .ndppc-infra-showcase-media-badge span {
  color: var(--ndppc-copy-soft);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.09em;
  text-transform: uppercase;
}

body[data-page="infra"] .ndppc-infra-showcase-media-dual .ndppc-infra-showcase-media-badge {
  top: 1.1rem;
  bottom: auto;
}

body[data-page="infra"] .ndppc-infra-showcase-copy {
  display: grid;
  align-content: start;
  gap: 1rem;
  padding: 1.65rem 1.75rem;
}

body[data-page="infra"] .ndppc-infra-showcase-head {
  display: grid;
  gap: 0.65rem;
}

body[data-page="infra"] .ndppc-infra-showcase-kicker {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  min-height: 32px;
  padding: 0.28rem 0.78rem;
  color: #8b6414;
  background: rgba(243, 236, 218, 0.95);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infra"] .ndppc-infra-showcase-copy h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.6rem, 2.3vw, 2.35rem);
  line-height: 1.14;
}

body[data-page="infra"] .ndppc-infra-showcase-lead {
  margin: 0;
  color: #173426;
  font-size: 1.02rem;
  font-weight: 600;
  line-height: 1.65;
}

body[data-page="infra"] .ndppc-infra-showcase-specs {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infra"] .ndppc-infra-showcase-specs span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0.35rem 0.8rem;
  border: 1px solid rgba(20, 53, 38, 0.09);
  color: var(--ndppc-primary-dark);
  background: rgba(255, 255, 255, 0.8);
  font-size: 0.86rem;
  font-weight: 700;
  line-height: 1.25;
}

body[data-page="infra"] .ndppc-infra-showcase-text {
  display: grid;
  gap: 0.78rem;
}

body[data-page="infra"] .ndppc-infra-showcase-text .ndppc-card-copy {
  margin: 0;
  text-align: justify;
}

body[data-page="infra"] .ndppc-infra-showcase-points {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.6rem 1rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

body[data-page="infra"] .ndppc-infra-showcase-points li {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 0.55rem;
  color: var(--ndppc-copy-soft);
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.45;
}

body[data-page="infra"] .ndppc-infra-showcase-points i {
  margin-top: 0.18rem;
  font-size: 0.82rem;
}

body[data-page="infra"] .ndppc-infra-showcase-green .ndppc-infra-showcase-kicker,
body[data-page="infra"] .ndppc-infra-showcase-green .ndppc-infra-showcase-specs span,
body[data-page="infra"] .ndppc-infra-showcase-green .ndppc-infra-showcase-media-badge {
  background: rgba(225, 239, 231, 0.95);
}

body[data-page="infra"] .ndppc-infra-showcase-green .ndppc-infra-showcase-kicker,
body[data-page="infra"] .ndppc-infra-showcase-green .ndppc-infra-showcase-points i {
  color: #20583a;
}

body[data-page="infra"] .ndppc-infra-showcase-bronze .ndppc-infra-showcase-kicker,
body[data-page="infra"] .ndppc-infra-showcase-bronze .ndppc-infra-showcase-specs span,
body[data-page="infra"] .ndppc-infra-showcase-bronze .ndppc-infra-showcase-media-badge {
  background: rgba(247, 238, 218, 0.95);
}

body[data-page="infra"] .ndppc-infra-showcase-bronze .ndppc-infra-showcase-kicker,
body[data-page="infra"] .ndppc-infra-showcase-bronze .ndppc-infra-showcase-points i {
  color: #8b6414;
}

body[data-page="infra"] .ndppc-infra-showcase-slate .ndppc-infra-showcase-kicker,
body[data-page="infra"] .ndppc-infra-showcase-slate .ndppc-infra-showcase-specs span,
body[data-page="infra"] .ndppc-infra-showcase-slate .ndppc-infra-showcase-media-badge {
  background: rgba(229, 236, 240, 0.95);
}

body[data-page="infra"] .ndppc-infra-showcase-slate .ndppc-infra-showcase-kicker,
body[data-page="infra"] .ndppc-infra-showcase-slate .ndppc-infra-showcase-points i {
  color: #355366;
}

@media (max-width: 991px) {
  body[data-page="infra"] .ndppc-infra-glimpse-band {
    padding-top: 24px;
  }

  body[data-page="infra"] .ndppc-infra-glimpse-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="infra"] .ndppc-infra-showcase-band {
    padding-top: 24px;
    padding-bottom: 34px;
  }

  body[data-page="infra"] .ndppc-infra-showcase,
  body[data-page="infra"] .ndppc-infra-showcase-reverse {
    grid-template-columns: 1fr;
  }

  body[data-page="infra"] .ndppc-infra-showcase-reverse .ndppc-infra-showcase-media,
  body[data-page="infra"] .ndppc-infra-showcase-reverse .ndppc-infra-showcase-copy {
    order: initial;
  }

  body[data-page="infra"] .ndppc-infra-showcase-media {
    min-height: 320px;
  }

  body[data-page="infra"] .ndppc-infra-showcase-media-screen img {
    min-height: 320px;
  }

  body[data-page="infra"] .ndppc-infra-showcase-media-dual {
    grid-template-rows: repeat(2, minmax(158px, 1fr));
  }

  body[data-page="infra"] .ndppc-infra-showcase-media-dual .ndppc-infra-showcase-media-screen img {
    min-height: 158px;
  }

  body[data-page="infra"] .ndppc-infra-showcase-points {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="infra"] .ndppc-infra-glimpse-stats {
    grid-template-columns: 1fr 1fr;
    gap: 0.72rem;
  }

  body[data-page="infra"] .ndppc-infra-glimpse-stat {
    min-height: 132px;
    padding: 0.92rem 0.8rem 0.86rem;
  }

  body[data-page="infra"] .ndppc-infra-glimpse-stat-icon {
    width: 50px;
    height: 50px;
  }

  body[data-page="infra"] .ndppc-infra-showcase-stack {
    gap: 1.25rem;
  }

  body[data-page="infra"] .ndppc-infra-showcase-media {
    min-height: 236px;
  }

  body[data-page="infra"] .ndppc-infra-showcase-media-screen img {
    min-height: 236px;
  }

  body[data-page="infra"] .ndppc-infra-showcase-media-dual {
    grid-template-rows: repeat(2, minmax(126px, 1fr));
  }

  body[data-page="infra"] .ndppc-infra-showcase-media-dual .ndppc-infra-showcase-media-screen img {
    min-height: 126px;
  }

  body[data-page="infra"] .ndppc-infra-showcase-copy {
    padding: 1.15rem 1rem;
  }

  body[data-page="infra"] .ndppc-infra-showcase-copy h2 {
    font-size: 1.55rem;
  }

  body[data-page="infra"] .ndppc-infra-showcase-lead {
    font-size: 0.95rem;
    line-height: 1.58;
  }

  body[data-page="infra"] .ndppc-infra-showcase-points {
    grid-template-columns: 1fr;
  }
}

/* Final Sensors Page Redesign */
body[data-page="infrastructure"] .ndppc-sensor-command-band,
body[data-page="infrastructure"] .ndppc-sensor-family-band,
body[data-page="infrastructure"] .ndppc-sensor-browser-band {
  padding-top: 30px;
  padding-bottom: 44px;
}

body[data-page="infrastructure"] .ndppc-sensor-command-shell {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(360px, 1.1fr);
  gap: 1.2rem;
  align-items: stretch;
}

body[data-page="infrastructure"] .ndppc-sensor-command-copy {
  display: grid;
  align-content: start;
  gap: 0.9rem;
  padding: 1.55rem 1.6rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 241, 230, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-command-copy h2,
body[data-page="infrastructure"] .ndppc-sensor-section-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
  line-height: 1.16;
}

body[data-page="infrastructure"] .ndppc-sensor-command-copy .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-section-head .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-family-copy .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-workflow-text .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-metric-card .ndppc-card-copy {
  margin: 0;
  text-align: justify;
}

body[data-page="infrastructure"] .ndppc-sensor-command-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

body[data-page="infrastructure"] .ndppc-sensor-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card {
  position: relative;
  display: grid;
  align-content: start;
  gap: 0.45rem;
  min-height: 166px;
  padding: 1.15rem 1rem 1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(246, 241, 230, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 4px;
  background: rgba(139, 100, 20, 0.5);
}

body[data-page="infrastructure"] .ndppc-sensor-metric-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(243, 236, 218, 0.96);
}

body[data-page="infrastructure"] .ndppc-sensor-metric-icon i {
  color: #8b6414;
  font-size: 1.05rem;
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.45rem, 2vw, 2rem);
  line-height: 1;
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.25;
}

body[data-page="infrastructure"] .ndppc-sensor-tone-emerald::after {
  background: rgba(34, 102, 67, 0.76);
}

body[data-page="infrastructure"] .ndppc-sensor-tone-bronze::after {
  background: rgba(139, 100, 20, 0.76);
}

body[data-page="infrastructure"] .ndppc-sensor-tone-aqua::after {
  background: rgba(34, 122, 130, 0.76);
}

body[data-page="infrastructure"] .ndppc-sensor-tone-slate::after {
  background: rgba(50, 80, 96, 0.76);
}

body[data-page="infrastructure"] .ndppc-sensor-tone-emerald .ndppc-sensor-metric-icon {
  background: rgba(223, 238, 229, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-tone-emerald .ndppc-sensor-metric-icon i {
  color: #20583a;
}

body[data-page="infrastructure"] .ndppc-sensor-tone-bronze .ndppc-sensor-metric-icon {
  background: rgba(247, 238, 218, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-tone-aqua .ndppc-sensor-metric-icon {
  background: rgba(224, 240, 241, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-tone-aqua .ndppc-sensor-metric-icon i {
  color: #2a7a82;
}

body[data-page="infrastructure"] .ndppc-sensor-tone-slate .ndppc-sensor-metric-icon {
  background: rgba(229, 236, 240, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-tone-slate .ndppc-sensor-metric-icon i {
  color: #355366;
}

body[data-page="infrastructure"] .ndppc-sensor-section-head {
  display: grid;
  gap: 0.75rem;
  margin-bottom: 1.35rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-showcase-stack {
  display: grid;
  gap: 2rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-showcase {
  display: grid;
  grid-template-columns: minmax(340px, 0.92fr) minmax(0, 1.08fr);
  align-items: stretch;
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 242, 232, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-family-showcase-reverse {
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, 0.92fr);
}

body[data-page="infrastructure"] .ndppc-sensor-family-showcase-reverse .ndppc-sensor-family-visual {
  order: 2;
}

body[data-page="infrastructure"] .ndppc-sensor-family-showcase-reverse .ndppc-sensor-family-copy {
  order: 1;
}

body[data-page="infrastructure"] .ndppc-sensor-family-visual {
  position: relative;
  margin: 0;
  min-height: 410px;
  background: #10281d;
}

body[data-page="infrastructure"] .ndppc-sensor-family-visual img {
  width: 100%;
  height: 100%;
  min-height: 410px;
  display: block;
  object-fit: cover;
}

body[data-page="infrastructure"] .ndppc-sensor-family-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7, 20, 14, 0.08), rgba(7, 20, 14, 0.4));
  pointer-events: none;
}

body[data-page="infrastructure"] .ndppc-sensor-family-visual-badge {
  position: absolute;
  left: 1.1rem;
  bottom: 1.1rem;
  z-index: 1;
  display: grid;
  gap: 0.18rem;
  min-width: 168px;
  padding: 0.9rem 1rem;
  background: rgba(255, 255, 255, 0.92);
}

body[data-page="infrastructure"] .ndppc-sensor-family-visual-badge strong {
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.2;
}

body[data-page="infrastructure"] .ndppc-sensor-family-visual-badge span {
  color: var(--ndppc-copy-soft);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-family-copy {
  display: grid;
  align-content: start;
  gap: 0.9rem;
  padding: 1.6rem 1.7rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-kicker {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  min-height: 32px;
  padding: 0.28rem 0.78rem;
  background: rgba(243, 236, 218, 0.95);
  color: #8b6414;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-family-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.58rem, 2.2vw, 2.25rem);
  line-height: 1.14;
}

body[data-page="infrastructure"] .ndppc-sensor-family-lead {
  margin: 0;
  color: #173426;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.65;
}

body[data-page="infrastructure"] .ndppc-sensor-family-specs,
body[data-page="infrastructure"] .ndppc-sensor-family-modules {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-specs span,
body[data-page="infrastructure"] .ndppc-sensor-family-modules span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0.35rem 0.78rem;
  border: 1px solid rgba(20, 53, 38, 0.09);
  color: var(--ndppc-primary-dark);
  background: rgba(255, 255, 255, 0.82);
  font-size: 0.85rem;
  font-weight: 700;
  line-height: 1.25;
}

body[data-page="infrastructure"] .ndppc-sensor-family-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-emerald .ndppc-sensor-family-kicker,
body[data-page="infrastructure"] .ndppc-sensor-family-emerald .ndppc-sensor-family-specs span,
body[data-page="infrastructure"] .ndppc-sensor-family-emerald .ndppc-sensor-family-visual-badge {
  background: rgba(225, 239, 231, 0.95);
}

body[data-page="infrastructure"] .ndppc-sensor-family-emerald .ndppc-sensor-family-kicker {
  color: #20583a;
}

body[data-page="infrastructure"] .ndppc-sensor-family-bronze .ndppc-sensor-family-kicker,
body[data-page="infrastructure"] .ndppc-sensor-family-bronze .ndppc-sensor-family-specs span,
body[data-page="infrastructure"] .ndppc-sensor-family-bronze .ndppc-sensor-family-visual-badge {
  background: rgba(247, 238, 218, 0.95);
}

body[data-page="infrastructure"] .ndppc-sensor-family-bronze .ndppc-sensor-family-kicker {
  color: #8b6414;
}

body[data-page="infrastructure"] .ndppc-sensor-family-slate .ndppc-sensor-family-kicker,
body[data-page="infrastructure"] .ndppc-sensor-family-slate .ndppc-sensor-family-specs span,
body[data-page="infrastructure"] .ndppc-sensor-family-slate .ndppc-sensor-family-visual-badge {
  background: rgba(229, 236, 240, 0.95);
}

body[data-page="infrastructure"] .ndppc-sensor-family-slate .ndppc-sensor-family-kicker {
  color: #355366;
}

body[data-page="infrastructure"] .ndppc-sensor-browser-shell-v2 {
  display: grid;
  gap: 1.2rem;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-rail {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-tab {
  display: grid;
  align-content: start;
  gap: 0.45rem;
  min-height: 150px;
  padding: 0.95rem 1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 241, 230, 0.96));
  text-align: left;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-tab-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-tab-code {
  color: #8b6414;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-tab small {
  color: var(--ndppc-copy-soft);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-tab strong {
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.3;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-tab-note {
  color: var(--ndppc-copy-soft);
  font-size: 0.84rem;
  line-height: 1.38;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-tab.active {
  border-color: rgba(20, 53, 38, 0.2);
  background: linear-gradient(180deg, rgba(20, 53, 38, 0.96), rgba(10, 34, 24, 0.97));
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-tab.active small,
body[data-page="infrastructure"] .ndppc-sensor-workflow-tab.active strong,
body[data-page="infrastructure"] .ndppc-sensor-workflow-tab.active .ndppc-sensor-workflow-tab-note,
body[data-page="infrastructure"] .ndppc-sensor-workflow-tab.active .ndppc-sensor-workflow-tab-code {
  color: #fff;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-detail {
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 242, 232, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-stage {
  display: grid;
  grid-template-columns: minmax(380px, 0.96fr) minmax(0, 1.04fr);
  align-items: stretch;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-visual {
  position: relative;
  margin: 0;
  min-height: 430px;
  background: #10281d;
  overflow: hidden;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-visual img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  display: block;
  object-fit: cover;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-visual::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(7, 20, 14, 0.08), rgba(7, 20, 14, 0.42));
  pointer-events: none;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-code,
body[data-page="infrastructure"] .ndppc-sensor-workflow-band {
  position: absolute;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0.35rem 0.8rem;
  background: rgba(255, 255, 255, 0.92);
  color: var(--ndppc-primary-dark);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-code {
  top: 1rem;
  left: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-band {
  top: 1rem;
  right: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-caption {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 1;
  display: grid;
  gap: 0.35rem;
  padding: 1rem 1.05rem;
  background: rgba(255, 255, 255, 0.92);
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-caption strong {
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.35;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-sidebar {
  display: grid;
  align-content: start;
  gap: 0.95rem;
  padding: 1.6rem 1.7rem;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.3rem 0.72rem;
  background: rgba(243, 236, 218, 0.95);
  color: #8b6414;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-sidebar h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.6rem, 2.2vw, 2.3rem);
  line-height: 1.14;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-lead {
  margin: 0;
  color: #173426;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.68;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-text {
  display: grid;
  gap: 0.8rem;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-outputs {
  display: grid;
  gap: 0.6rem;
}

body[data-page="infrastructure"] .ndppc-sensor-workflow-outputs strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.92rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

@media (max-width: 1199px) {
  body[data-page="infrastructure"] .ndppc-sensor-command-shell,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-stage,
  body[data-page="infrastructure"] .ndppc-sensor-family-showcase,
  body[data-page="infrastructure"] .ndppc-sensor-family-showcase-reverse {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-family-showcase-reverse .ndppc-sensor-family-visual,
  body[data-page="infrastructure"] .ndppc-sensor-family-showcase-reverse .ndppc-sensor-family-copy {
    order: initial;
  }

  body[data-page="infrastructure"] .ndppc-sensor-workflow-rail {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body[data-page="infrastructure"] .ndppc-sensor-command-band,
  body[data-page="infrastructure"] .ndppc-sensor-family-band,
  body[data-page="infrastructure"] .ndppc-sensor-browser-band {
    padding-top: 24px;
    padding-bottom: 34px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-metric-grid,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-rail {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="infrastructure"] .ndppc-sensor-family-visual,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-visual {
    min-height: 320px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-family-visual img,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-visual img {
    min-height: 320px;
  }
}

@media (max-width: 767px) {
  body[data-page="infrastructure"] .ndppc-sensor-command-band,
  body[data-page="infrastructure"] .ndppc-sensor-family-band,
  body[data-page="infrastructure"] .ndppc-sensor-browser-band {
    padding-top: 22px;
    padding-bottom: 28px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-command-copy,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-sidebar,
  body[data-page="infrastructure"] .ndppc-sensor-family-copy {
    padding: 1.1rem 1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-metric-grid,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-rail {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-family-visual,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-visual {
    min-height: 235px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-family-visual img,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-visual img {
    min-height: 235px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-command-copy h2,
  body[data-page="infrastructure"] .ndppc-sensor-section-head h2,
  body[data-page="infrastructure"] .ndppc-sensor-family-copy h3,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-sidebar h3 {
    font-size: 1.54rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-workflow-caption {
    left: 0.8rem;
    right: 0.8rem;
    bottom: 0.8rem;
    padding: 0.85rem 0.9rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-workflow-code,
  body[data-page="infrastructure"] .ndppc-sensor-workflow-band {
    top: 0.8rem;
    min-height: 30px;
    padding: 0.28rem 0.65rem;
    font-size: 0.74rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-workflow-code {
    left: 0.8rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-workflow-band {
    right: 0.8rem;
  }
}

/* Final Sensors Explorer Redesign */
body[data-page="infrastructure"] .ndppc-sensor-intro-band,
body[data-page="infrastructure"] .ndppc-sensor-map-band,
body[data-page="infrastructure"] .ndppc-sensor-explorer-band {
  padding-top: 30px;
  padding-bottom: 44px;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-band {
  padding-top: 8px;
}

body[data-page="infrastructure"] .ndppc-sensor-intro-shell {
  display: grid;
  grid-template-columns: minmax(0, 0.88fr) minmax(360px, 1.12fr);
  gap: 1.2rem;
  align-items: stretch;
}

body[data-page="infrastructure"] .ndppc-sensor-intro-copy {
  display: grid;
  align-content: start;
  gap: 0.9rem;
  padding: 1.6rem 1.7rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 241, 230, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-intro-copy h2,
body[data-page="infrastructure"] .ndppc-sensor-section-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
  line-height: 1.16;
}

body[data-page="infrastructure"] .ndppc-sensor-intro-copy .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-section-head .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-family-card-v4 .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-console-text .ndppc-card-copy,
body[data-page="infrastructure"] .ndppc-sensor-metric-card-v4 .ndppc-card-copy {
  margin: 0;
  text-align: justify;
}

body[data-page="infrastructure"] .ndppc-sensor-intro-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
}

body[data-page="infrastructure"] .ndppc-sensor-metric-grid-v4 {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card-v4,
body[data-page="infrastructure"] .ndppc-sensor-family-card-v4,
body[data-page="infrastructure"] .ndppc-sensor-explorer-group,
body[data-page="infrastructure"] .ndppc-sensor-explorer-tab,
body[data-page="infrastructure"] .ndppc-sensor-console-panel {
  --ndppc-sensor-accent: #8b6414;
  --ndppc-sensor-soft: rgba(247, 238, 218, 0.96);
}

body[data-page="infrastructure"] .ndppc-sensor-metric-emerald,
body[data-page="infrastructure"] .ndppc-sensor-family-card-emerald,
body[data-page="infrastructure"] .ndppc-sensor-track-emerald {
  --ndppc-sensor-accent: #20583a;
  --ndppc-sensor-soft: rgba(223, 238, 229, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-metric-bronze,
body[data-page="infrastructure"] .ndppc-sensor-family-card-bronze,
body[data-page="infrastructure"] .ndppc-sensor-track-bronze {
  --ndppc-sensor-accent: #8b6414;
  --ndppc-sensor-soft: rgba(247, 238, 218, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-metric-aqua {
  --ndppc-sensor-accent: #2a7a82;
  --ndppc-sensor-soft: rgba(224, 240, 241, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-metric-slate,
body[data-page="infrastructure"] .ndppc-sensor-family-card-slate,
body[data-page="infrastructure"] .ndppc-sensor-track-slate {
  --ndppc-sensor-accent: #355366;
  --ndppc-sensor-soft: rgba(229, 236, 240, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card-v4 {
  position: relative;
  display: grid;
  align-content: start;
  gap: 0.45rem;
  min-height: 166px;
  padding: 1.1rem 1rem 0.95rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.14), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(246, 241, 230, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card-v4::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 4px;
  background: var(--ndppc-sensor-accent);
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: var(--ndppc-sensor-soft);
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card-icon i {
  color: var(--ndppc-sensor-accent);
  font-size: 1.08rem;
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card-v4 strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.45rem, 2vw, 2rem);
  line-height: 1;
}

body[data-page="infrastructure"] .ndppc-sensor-metric-card-v4 h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.25;
}

body[data-page="infrastructure"] .ndppc-sensor-section-head {
  display: grid;
  gap: 0.75rem;
  margin-bottom: 1.35rem;
}

body[data-page="infrastructure"] .ndppc-sensor-map-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-v4 {
  position: relative;
  display: grid;
  align-content: start;
  gap: 0.85rem;
  min-height: 100%;
  padding: 1.2rem 1.15rem 1.1rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 241, 230, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-v4::after {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--ndppc-sensor-accent);
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-top {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  gap: 0.8rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 999px;
  background: var(--ndppc-sensor-soft);
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-icon i {
  color: var(--ndppc-sensor-accent);
  font-size: 1.08rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-head {
  display: grid;
  gap: 0.2rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-head span {
  color: var(--ndppc-sensor-accent);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-head h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.36rem;
  line-height: 1.2;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-lead {
  margin: 0;
  color: #173426;
  font-size: 0.96rem;
  font-weight: 600;
  line-height: 1.6;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-specs,
body[data-page="infrastructure"] .ndppc-sensor-family-card-modules {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

body[data-page="infrastructure"] .ndppc-sensor-family-card-specs span,
body[data-page="infrastructure"] .ndppc-sensor-family-card-modules span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0.34rem 0.75rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.82);
  color: var(--ndppc-primary-dark);
  font-size: 0.82rem;
  font-weight: 700;
}

body[data-page="infrastructure"] .ndppc-sensor-family-points,
body[data-page="infrastructure"] .ndppc-sensor-stage-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-shell {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.2rem;
  align-items: start;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-band .ndppc-sensor-section-head {
  margin-bottom: 0.8rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-nav {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.8rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-group {
  display: grid;
  grid-template-columns: minmax(220px, 0.28fr) minmax(0, 0.72fr);
  align-items: stretch;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(249, 246, 239, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-group-head {
  display: grid;
  align-content: start;
  gap: 0.24rem;
  padding: 0.95rem 1rem;
  border-right: 1px solid rgba(20, 53, 38, 0.08);
  background: var(--ndppc-sensor-soft);
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-group-head strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.95rem;
  line-height: 1.3;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-group-head span {
  color: var(--ndppc-copy-soft);
  font-size: 0.76rem;
  line-height: 1.35;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-group-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.48rem;
  padding: 0.62rem;
  align-content: start;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tab {
  position: relative;
  display: grid;
  gap: 0.22rem;
  min-height: 74px;
  padding: 0.56rem 0.68rem;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.94);
  text-align: left;
  overflow: hidden;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tab-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.55rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tab .rounded-pill {
  min-height: 22px;
  padding: 0.12rem 0.42rem;
  font-size: 0.62rem;
  letter-spacing: 0.05em;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tab-code {
  color: var(--ndppc-sensor-accent);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tab-copy {
  display: grid;
  gap: 0.04rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tab-copy strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.82rem;
  line-height: 1.16;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tab.active {
  border-color: rgba(20, 53, 38, 0.16);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), var(--ndppc-sensor-soft));
  box-shadow: inset 3px 0 0 var(--ndppc-sensor-accent);
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tab.active .ndppc-sensor-explorer-tab-code,
body[data-page="infrastructure"] .ndppc-sensor-explorer-tab.active .ndppc-sensor-explorer-tab-copy strong {
  color: var(--ndppc-primary-dark);
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tab.active .ndppc-sensor-explorer-tab-code {
  color: var(--ndppc-sensor-accent);
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-stage {
  min-height: 100%;
}

body[data-page="infrastructure"] .ndppc-sensor-console-panel {
  overflow: hidden;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 242, 232, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-console-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.95rem 1.1rem;
  background: #10281d;
}

body[data-page="infrastructure"] .ndppc-sensor-console-codeblock {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.55rem;
}

body[data-page="infrastructure"] .ndppc-sensor-console-code,
body[data-page="infrastructure"] .ndppc-sensor-console-band {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.3rem 0.74rem;
  background: var(--ndppc-sensor-soft);
  color: var(--ndppc-sensor-accent);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

body[data-page="infrastructure"] .ndppc-sensor-console-family {
  color: rgba(255, 255, 255, 0.82);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-console-body {
  display: grid;
  grid-template-columns: minmax(380px, 0.98fr) minmax(0, 1.02fr);
  align-items: stretch;
}

body[data-page="infrastructure"] .ndppc-sensor-console-visual {
  position: relative;
  margin: 0;
  min-height: 430px;
  overflow: hidden;
  background:
    radial-gradient(circle at top left, rgba(112, 157, 129, 0.18), transparent 28%),
    linear-gradient(180deg, rgba(14, 35, 25, 0.98), rgba(8, 28, 20, 0.98));
}

body[data-page="infrastructure"] .ndppc-sensor-console-visual img {
  width: 100%;
  height: 100%;
  min-height: 430px;
  display: block;
  object-fit: contain;
  padding: 2rem;
}

body[data-page="infrastructure"] .ndppc-sensor-console-icon,
body[data-page="infrastructure"] .ndppc-sensor-console-note {
  position: absolute;
  z-index: 1;
}

body[data-page="infrastructure"] .ndppc-sensor-console-icon {
  top: 1rem;
  left: 1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 999px;
  background: var(--ndppc-sensor-soft);
}

body[data-page="infrastructure"] .ndppc-sensor-console-icon i {
  color: var(--ndppc-sensor-accent);
  font-size: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-console-note {
  top: 1rem;
  left: 4.6rem;
  right: 1rem;
  display: inline-flex;
  min-height: 36px;
  align-items: center;
  padding: 0.36rem 0.78rem;
  background: rgba(255, 255, 255, 0.9);
  color: var(--ndppc-primary-dark);
  font-size: 0.82rem;
  font-weight: 700;
  line-height: 1.35;
}

body[data-page="infrastructure"] .ndppc-sensor-console-caption {
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  z-index: 1;
  display: grid;
  gap: 0.2rem;
  padding: 0.95rem 1rem;
  background: rgba(255, 255, 255, 0.9);
}

body[data-page="infrastructure"] .ndppc-sensor-console-caption strong {
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.3;
}

body[data-page="infrastructure"] .ndppc-sensor-console-caption span {
  color: var(--ndppc-copy-soft);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-console-copy {
  display: grid;
  align-content: start;
  gap: 0.95rem;
  padding: 1.4rem 1.45rem;
}

body[data-page="infrastructure"] .ndppc-sensor-console-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
}

body[data-page="infrastructure"] .ndppc-sensor-console-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.3rem 0.72rem;
  background: var(--ndppc-sensor-soft);
  color: var(--ndppc-sensor-accent);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-console-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.62rem, 2.2vw, 2.3rem);
  line-height: 1.14;
}

body[data-page="infrastructure"] .ndppc-sensor-console-lead {
  margin: 0;
  color: #173426;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.68;
}

body[data-page="infrastructure"] .ndppc-sensor-console-text {
  display: grid;
  gap: 0.78rem;
}

body[data-page="infrastructure"] .ndppc-sensor-console-outputs {
  display: grid;
  gap: 0.6rem;
}

body[data-page="infrastructure"] .ndppc-sensor-console-outputs strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.92rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

@media (max-width: 1199px) {
  body[data-page="infrastructure"] .ndppc-sensor-intro-shell,
  body[data-page="infrastructure"] .ndppc-sensor-console-body {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-map-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-explorer-nav {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-explorer-group {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-explorer-group-head {
    border-right: 0;
    border-bottom: 1px solid rgba(20, 53, 38, 0.08);
  }
}

@media (max-width: 991px) {
  body[data-page="infrastructure"] .ndppc-sensor-intro-band,
  body[data-page="infrastructure"] .ndppc-sensor-map-band,
  body[data-page="infrastructure"] .ndppc-sensor-explorer-band {
    padding-top: 24px;
    padding-bottom: 34px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-explorer-band {
    padding-top: 6px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-metric-grid-v4 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="infrastructure"] .ndppc-sensor-console-visual {
    min-height: 320px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-console-visual img {
    min-height: 320px;
    padding: 1.6rem;
  }
}

@media (max-width: 767px) {
  body[data-page="infrastructure"] .ndppc-sensor-intro-band,
  body[data-page="infrastructure"] .ndppc-sensor-map-band,
  body[data-page="infrastructure"] .ndppc-sensor-explorer-band {
    padding-top: 22px;
    padding-bottom: 28px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-explorer-band {
    padding-top: 4px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-intro-copy,
  body[data-page="infrastructure"] .ndppc-sensor-family-card-v4,
  body[data-page="infrastructure"] .ndppc-sensor-console-copy {
    padding: 1.1rem 1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-metric-grid-v4 {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-explorer-group-list {
    grid-auto-columns: minmax(140px, 1fr);
  }

  body[data-page="infrastructure"] .ndppc-sensor-console-visual {
    min-height: 236px;
  }

  body[data-page="infrastructure"] .ndppc-sensor-console-visual img {
    min-height: 236px;
    padding: 1.1rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-intro-copy h2,
  body[data-page="infrastructure"] .ndppc-sensor-section-head h2,
  body[data-page="infrastructure"] .ndppc-sensor-console-copy h3 {
    font-size: 1.54rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-console-note {
    left: 0.8rem;
    right: 0.8rem;
    top: 0.8rem;
    min-height: 32px;
    font-size: 0.76rem;
  }

  body[data-page="infrastructure"] .ndppc-sensor-console-icon {
    display: none;
  }

  body[data-page="infrastructure"] .ndppc-sensor-console-caption {
    left: 0.8rem;
    right: 0.8rem;
    bottom: 0.8rem;
    padding: 0.8rem 0.85rem;
  }
}

/* Final Ungrouped Sensor Explorer */
body[data-page="infrastructure"] .ndppc-sensor-explorer-shell {
  gap: 1rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-nav {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.8rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile {
  --ndppc-sensor-accent: #8b6414;
  --ndppc-sensor-soft: rgba(247, 238, 218, 0.97);
  position: relative;
  display: grid !important;
  align-content: start;
  gap: 0.42rem;
  min-height: 132px;
  width: 100%;
  padding: 0.88rem 0.92rem 0.84rem;
  border-radius: 16px !important;
  border: 1px solid rgba(20, 53, 38, 0.1);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
  text-align: left;
  overflow: hidden;
  box-shadow: none;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile.ndppc-sensor-track-emerald {
  --ndppc-sensor-accent: #20583a;
  --ndppc-sensor-soft: rgba(223, 238, 229, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile.ndppc-sensor-track-slate {
  --ndppc-sensor-accent: #355366;
  --ndppc-sensor-soft: rgba(229, 236, 240, 0.97);
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  background: var(--ndppc-sensor-accent);
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile .ndppc-sensor-explorer-tab-top {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 0.55rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile .ndppc-sensor-explorer-tab-code {
  color: var(--ndppc-sensor-accent);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile .rounded-pill {
  min-height: 23px;
  padding: 0.14rem 0.48rem;
  background: var(--ndppc-sensor-soft);
  color: var(--ndppc-sensor-accent);
  font-size: 0.64rem;
  letter-spacing: 0.01em;
  text-transform: none;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile-meta {
  display: flex;
  align-items: center;
  gap: 0.48rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: var(--ndppc-sensor-soft);
  color: var(--ndppc-sensor-accent);
  font-size: 0.82rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile-family {
  color: var(--ndppc-copy-soft);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile .ndppc-sensor-explorer-tab-copy {
  display: grid;
  gap: 0.16rem;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile .ndppc-sensor-explorer-tab-copy strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.98rem;
  line-height: 1.16;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile .ndppc-sensor-explorer-tab-copy span {
  color: var(--ndppc-copy-soft);
  font-size: 0.76rem;
  line-height: 1.26;
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile.active {
  border-color: rgba(20, 53, 38, 0.14);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), var(--ndppc-sensor-soft));
  box-shadow: 0 14px 28px rgba(18, 44, 34, 0.07);
  transform: translateY(-1px);
}

body[data-page="infrastructure"] .ndppc-sensor-explorer-tile.active .ndppc-sensor-explorer-tab-copy strong {
  color: var(--ndppc-primary-dark);
}

@media (max-width: 1399px) {
  body[data-page="infrastructure"] .ndppc-sensor-explorer-nav {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body[data-page="infrastructure"] .ndppc-sensor-explorer-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="infrastructure"] .ndppc-sensor-explorer-tile {
    min-height: 122px;
  }
}

@media (max-width: 767px) {
  body[data-page="infrastructure"] .ndppc-sensor-explorer-nav {
    grid-template-columns: 1fr;
  }

  body[data-page="infrastructure"] .ndppc-sensor-explorer-tile {
    min-height: 112px;
    padding: 0.78rem 0.82rem 0.76rem;
  }
}

/* Final Sensor Console Backgrounds */
body[data-page="infrastructure"] .ndppc-sensor-console-panel .ndppc-sensor-console-visual {
  background:
    radial-gradient(circle at top left, rgba(184, 146, 66, 0.14), transparent 30%),
    radial-gradient(circle at bottom right, rgba(201, 181, 136, 0.16), transparent 28%),
    linear-gradient(180deg, rgba(248, 243, 232, 0.99), rgba(239, 231, 213, 0.99));
}

body[data-page="infrastructure"] .ndppc-sensor-console-panel.ndppc-sensor-track-emerald .ndppc-sensor-console-visual {
  background:
    radial-gradient(circle at top left, rgba(76, 130, 99, 0.16), transparent 30%),
    radial-gradient(circle at bottom right, rgba(132, 181, 152, 0.18), transparent 28%),
    linear-gradient(180deg, rgba(233, 243, 237, 0.99), rgba(214, 232, 221, 0.99));
}

body[data-page="infrastructure"] .ndppc-sensor-console-panel.ndppc-sensor-track-bronze .ndppc-sensor-console-visual {
  background:
    radial-gradient(circle at top left, rgba(184, 146, 66, 0.14), transparent 30%),
    radial-gradient(circle at bottom right, rgba(201, 181, 136, 0.16), transparent 28%),
    linear-gradient(180deg, rgba(248, 243, 232, 0.99), rgba(239, 231, 213, 0.99));
}

body[data-page="infrastructure"] .ndppc-sensor-console-panel.ndppc-sensor-track-slate .ndppc-sensor-console-visual {
  background:
    radial-gradient(circle at top left, rgba(71, 109, 140, 0.16), transparent 30%),
    radial-gradient(circle at bottom right, rgba(154, 178, 198, 0.18), transparent 28%),
    linear-gradient(180deg, rgba(235, 241, 245, 0.99), rgba(218, 228, 236, 0.99));
}

/* Final Team Gradient Sync */
body[data-page="team"] .ndppc-team-directory-overview,
body[data-page="team"] .ndppc-team-directory-meta,
body[data-page="team"] .ndppc-team-overview-stat,
body[data-page="team"] .ndppc-home-team-lead,
body[data-page="team"] .ndppc-home-team-lead-copy,
body[data-page="team"] .ndppc-team-page-mini,
body[data-page="team"] .ndppc-team-page-mini-associate,
body[data-page="team"] .ndppc-team-page-mini-scholar {
  position: relative;
  overflow: hidden;
}

body[data-page="team"] .ndppc-team-directory-overview {
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
}

body[data-page="team"] .ndppc-team-directory-meta {
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
}

body[data-page="team"] .ndppc-team-overview-stat:nth-child(1) {
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.15), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(233, 243, 237, 0.98));
}

body[data-page="team"] .ndppc-team-overview-stat:nth-child(2) {
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
}

body[data-page="team"] .ndppc-team-overview-stat:nth-child(3) {
  background:
    radial-gradient(circle at top right, rgba(71, 109, 140, 0.15), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(235, 241, 245, 0.98));
}

body[data-page="team"] .ndppc-home-team-lead {
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.15), transparent 30%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(233, 243, 237, 0.98));
}

body[data-page="team"] .ndppc-home-team-lead-copy {
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.14), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(233, 243, 237, 0.98));
}

body[data-page="team"] .ndppc-home-team-lead-media {
  background: rgba(223, 238, 229, 0.97);
}

body[data-page="team"] .ndppc-team-page-mini-associate {
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
}

body[data-page="team"] .ndppc-team-page-mini-scholar {
  background:
    radial-gradient(circle at top right, rgba(71, 109, 140, 0.15), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(235, 241, 245, 0.98));
}

/* Final Projects Page Redesign */
body[data-page="projects"] .banner.ndppc-projects-banner {
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
}

body[data-page="projects"] .banner.ndppc-projects-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="projects"] .banner.ndppc-projects-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="projects"] .banner_content.ndppc-projects-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="projects"] .ndppc-projects-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="projects"] .ndppc-projects-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="projects"] .ndppc-projects-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(247, 243, 233, 0.96) 0%, rgba(247, 243, 233, 0.92) 32%, rgba(247, 243, 233, 0.68) 58%, rgba(247, 243, 233, 0.18) 100%);
  z-index: 1;
}

body[data-page="projects"] .ndppc-projects-banner-copy {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.55rem;
  width: min(1320px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 1rem 0;
}

body[data-page="projects"] .ndppc-projects-banner-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.92rem;
  font-weight: 600;
  color: rgba(18, 44, 34, 0.72);
}

body[data-page="projects"] .ndppc-projects-banner-breadcrumbs a {
  color: var(--ndppc-primary-dark);
}

body[data-page="projects"] .ndppc-projects-banner-copy .rounded-pill {
  align-self: flex-start;
}

body[data-page="projects"] .ndppc-projects-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.15vw, 2.2rem);
  line-height: 1.08;
}

body[data-page="projects"] .ndppc-projects-page-shell {
  padding-top: 30px;
}

body[data-page="projects"] .ndppc-projects-overview {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(320px, 0.88fr);
  gap: 1.2rem;
  margin-bottom: 1.55rem;
}

body[data-page="projects"] .ndppc-projects-overview-copy {
  display: grid;
  align-content: start;
  gap: 0.95rem;
  padding: 1.45rem 1.5rem;
  border-radius: 28px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.16), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 243, 233, 0.98));
}

body[data-page="projects"] .ndppc-projects-overview-copy h2,
body[data-page="projects"] .ndppc-projects-archive-head h3,
body[data-page="projects"] .ndppc-projects-board-intro h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
  line-height: 1.14;
}

body[data-page="projects"] .ndppc-projects-overview-copy .ndppc-card-copy,
body[data-page="projects"] .ndppc-projects-archive-head .ndppc-card-copy,
body[data-page="projects"] .ndppc-projects-board-intro p {
  margin: 0;
  color: var(--ndppc-copy);
  line-height: 1.72;
  text-align: justify;
}

body[data-page="projects"] .ndppc-projects-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  padding-top: 0.1rem;
}

body[data-page="projects"] .ndppc-projects-focus-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="projects"] .ndppc-projects-focus-card {
  display: grid;
  gap: 0.4rem;
  align-content: start;
  min-height: 138px;
  padding: 1rem 1rem 0.95rem;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.7);
}

body[data-page="projects"] .ndppc-projects-focus-card .material-symbols-outlined {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  font-size: 1.4rem;
}

body[data-page="projects"] .ndppc-projects-focus-card strong {
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.3;
}

body[data-page="projects"] .ndppc-projects-focus-card small {
  color: var(--ndppc-copy);
  font-size: 0.84rem;
  line-height: 1.55;
}

body[data-page="projects"] .ndppc-projects-focus-card-emerald {
  background:
    linear-gradient(180deg, rgba(237, 247, 241, 0.98), rgba(229, 242, 235, 0.98));
}

body[data-page="projects"] .ndppc-projects-focus-card-emerald .material-symbols-outlined {
  background: rgba(33, 91, 63, 0.12);
  color: #215b3f;
}

body[data-page="projects"] .ndppc-projects-focus-card-bronze {
  background:
    linear-gradient(180deg, rgba(249, 243, 230, 0.98), rgba(244, 236, 220, 0.98));
}

body[data-page="projects"] .ndppc-projects-focus-card-bronze .material-symbols-outlined {
  background: rgba(166, 114, 25, 0.12);
  color: #9a6717;
}

body[data-page="projects"] .ndppc-projects-focus-card-slate {
  background:
    linear-gradient(180deg, rgba(239, 244, 248, 0.98), rgba(231, 239, 245, 0.98));
}

body[data-page="projects"] .ndppc-projects-focus-card-slate .material-symbols-outlined {
  background: rgba(58, 101, 128, 0.12);
  color: #3a6580;
}

body[data-page="projects"] .ndppc-projects-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="projects"] .ndppc-projects-metric {
  display: grid;
  gap: 0.3rem;
  align-content: start;
  min-height: 132px;
  padding: 1.05rem 1rem 0.95rem;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
}

body[data-page="projects"] .ndppc-projects-metric-emerald {
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(233, 243, 237, 0.98));
}

body[data-page="projects"] .ndppc-projects-metric-slate {
  background:
    radial-gradient(circle at top right, rgba(71, 109, 140, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(235, 241, 245, 0.98));
}

body[data-page="projects"] .ndppc-projects-metric strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.8rem, 2.35vw, 2.35rem);
  line-height: 1;
}

body[data-page="projects"] .ndppc-projects-metric span {
  color: var(--ndppc-copy);
  font-weight: 700;
}

body[data-page="projects"] .ndppc-projects-board {
  display: grid;
  gap: 1.1rem;
  padding: 1.35rem 1.35rem 1.25rem;
  border-radius: 28px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.14), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 243, 233, 0.98));
}

body[data-page="projects"] .ndppc-projects-board-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
}

body[data-page="projects"] .ndppc-projects-board-intro {
  display: grid;
  gap: 0.45rem;
}

body[data-page="projects"] .ndppc-projects-board-meta {
  min-width: 132px;
  min-height: 118px;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 0.2rem;
  padding: 0.9rem 1rem;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(71, 109, 140, 0.14), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(235, 241, 245, 0.98));
}

body[data-page="projects"] .ndppc-projects-board-meta strong {
  color: var(--ndppc-primary-dark);
  font-size: 2rem;
  line-height: 1;
}

body[data-page="projects"] .ndppc-projects-board-meta span {
  color: var(--ndppc-copy-soft);
  font-size: 0.82rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

body[data-page="projects"] .ndppc-projects-tab-row {
  margin-bottom: 0;
}

body[data-page="projects"] .ndppc-projects-tab-row button {
  min-height: 42px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ndppc-primary-dark);
  cursor: pointer;
}

body[data-page="projects"] .ndppc-projects-tab-row button.active {
  background: linear-gradient(180deg, rgba(234, 244, 238, 0.98), rgba(224, 238, 230, 0.98));
  border-color: rgba(33, 91, 63, 0.2);
  color: #215b3f;
}

body[data-page="projects"] .ndppc-projects-tab-row button:hover {
  background: rgba(247, 242, 233, 0.92);
}

body[data-page="projects"] .ndppc-projects-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="projects"] .ndppc-projects-archive-band {
  padding-top: 20px;
}

body[data-page="projects"] .ndppc-projects-archive-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: end;
  margin-bottom: 1.05rem;
}

body[data-page="projects"] .ndppc-projects-archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="projects"] .ndppc-projects-archive-card {
  display: grid;
  gap: 0.7rem;
  align-content: start;
  padding: 1.15rem 1.1rem;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
}

body[data-page="projects"] .ndppc-projects-archive-card h4 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.08rem;
  line-height: 1.35;
}

body[data-page="projects"] .ndppc-projects-archive-card p {
  margin: 0;
  color: var(--ndppc-copy);
  line-height: 1.68;
}

body[data-page="projects"] .ndppc-project-card,
body[data-page="project-details"] .ndppc-project-card {
  display: grid;
  grid-template-columns: minmax(220px, 0.92fr) minmax(0, 1.08fr);
  gap: 0;
  overflow: hidden;
  border-radius: 26px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
  box-shadow: 0 20px 36px rgba(18, 37, 28, 0.07);
  padding: 0;
}

body[data-page="projects"] .ndppc-project-card-ongoing,
body[data-page="project-details"] .ndppc-project-card-ongoing {
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(233, 243, 237, 0.98));
}

body[data-page="projects"] .ndppc-project-card-media,
body[data-page="project-details"] .ndppc-project-card-media {
  display: flex;
  background: rgba(244, 237, 222, 0.72);
}

body[data-page="projects"] .ndppc-project-card-ongoing .ndppc-project-card-media,
body[data-page="project-details"] .ndppc-project-card-ongoing .ndppc-project-card-media {
  background: rgba(223, 238, 229, 0.86);
}

body[data-page="projects"] .ndppc-project-card-media img,
body[data-page="project-details"] .ndppc-project-card-media img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  display: block;
  object-fit: cover;
}

body[data-page="projects"] .ndppc-project-card-copy,
body[data-page="project-details"] .ndppc-project-card-copy {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  padding: 1.3rem 1.3rem 1.2rem;
}

body[data-page="projects"] .ndppc-project-card-top,
body[data-page="project-details"] .ndppc-project-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 0.7rem;
}

body[data-page="projects"] .ndppc-project-card-programme,
body[data-page="project-details"] .ndppc-project-card-programme {
  color: var(--ndppc-copy-soft);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="projects"] .ndppc-project-card h3,
body[data-page="project-details"] .ndppc-project-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.22rem;
  line-height: 1.42;
}

body[data-page="projects"] .ndppc-project-card-duration,
body[data-page="project-details"] .ndppc-project-card-duration {
  margin: -0.15rem 0 0;
  color: var(--ndppc-copy);
  font-size: 0.9rem;
  line-height: 1.6;
}

body[data-page="projects"] .ndppc-project-card-duration strong,
body[data-page="project-details"] .ndppc-project-card-duration strong {
  color: var(--ndppc-primary-dark);
}

body[data-page="project-details"] .ndppc-project-card-investigator {
  margin: -0.15rem 0 0;
  color: var(--ndppc-copy);
  font-size: 0.92rem;
  line-height: 1.65;
}

body[data-page="project-details"] .ndppc-project-card-investigator strong {
  color: var(--ndppc-primary-dark);
}

body[data-page="project-details"] .ndppc-project-card-objectives {
  display: grid;
  gap: 0.4rem;
  margin-top: -0.1rem;
}

body[data-page="project-details"] .ndppc-project-card-objectives > strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.95rem;
}

body[data-page="project-details"] .ndppc-project-card-objectives ol {
  margin: 0;
  padding-left: 1.15rem;
  color: var(--ndppc-copy);
}

body[data-page="project-details"] .ndppc-project-card-objectives li {
  margin: 0 0 0.35rem;
  line-height: 1.62;
}

body[data-page="project-details"] .ndppc-project-card-objectives li:last-child {
  margin-bottom: 0;
}

body[data-page="projects"] .ndppc-project-card-tags,
body[data-page="project-details"] .ndppc-project-card-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

body[data-page="projects"] .ndppc-project-card-tags span,
body[data-page="project-details"] .ndppc-project-card-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.2rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.72);
  color: var(--ndppc-primary-dark);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.2;
}

body[data-page="projects"] .ndppc-project-card .ndppc-inline-link,
body[data-page="project-details"] .ndppc-project-card .ndppc-inline-link {
  margin-top: auto;
}

@media (max-width: 1199px) {
  body[data-page="projects"] .ndppc-projects-banner-copy {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body[data-page="projects"] .ndppc-projects-overview,
  body[data-page="projects"] .ndppc-projects-board-head,
  body[data-page="projects"] .ndppc-projects-archive-head {
    grid-template-columns: 1fr;
  }

  body[data-page="projects"] .ndppc-projects-focus-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="projects"] .ndppc-projects-archive-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body[data-page="projects"] .ndppc-projects-banner-frame,
  body[data-page="projects"] .ndppc-projects-banner-frame img {
    min-height: 102px;
  }

  body[data-page="projects"] .ndppc-projects-metrics,
  body[data-page="projects"] .ndppc-projects-grid,
  body[data-page="projects"] .ndppc-projects-archive-grid,
  body[data-page="projects"] .ndppc-projects-focus-grid,
  body[data-page="project-details"] .ndppc-card-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="projects"] .ndppc-project-card,
  body[data-page="project-details"] .ndppc-project-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="projects"] .ndppc-projects-banner-frame,
  body[data-page="projects"] .ndppc-projects-banner-frame img {
    min-height: 88px;
  }

  body[data-page="projects"] .ndppc-projects-banner-copy {
    padding: 0.75rem 1rem;
  }

  body[data-page="projects"] .ndppc-projects-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="projects"] .ndppc-projects-page-shell {
    padding-top: 22px;
  }

  body[data-page="projects"] .ndppc-projects-overview-copy,
  body[data-page="projects"] .ndppc-projects-board,
  body[data-page="projects"] .ndppc-projects-archive-card {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body[data-page="projects"] .ndppc-project-card-copy,
  body[data-page="project-details"] .ndppc-project-card-copy {
    padding: 1rem;
  }
}

/* Project Archive Page */
body[data-page="project-details"] .banner.ndppc-project-archive-banner {
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
}

body[data-page="project-details"] .banner.ndppc-project-archive-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="project-details"] .banner.ndppc-project-archive-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="project-details"] .banner_content.ndppc-project-archive-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="project-details"] .ndppc-project-archive-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="project-details"] .ndppc-project-archive-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="project-details"] .ndppc-project-archive-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(247, 243, 233, 0.96) 0%, rgba(247, 243, 233, 0.92) 34%, rgba(247, 243, 233, 0.68) 60%, rgba(247, 243, 233, 0.18) 100%);
  z-index: 1;
}

body[data-page="project-details"] .ndppc-project-archive-banner-copy {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.55rem;
  width: min(1320px, calc(100% - 2rem));
  margin: 0 auto;
  padding: 1rem 0;
}

body[data-page="project-details"] .ndppc-project-archive-banner-breadcrumbs {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.92rem;
  font-weight: 600;
  color: rgba(18, 44, 34, 0.72);
}

body[data-page="project-details"] .ndppc-project-archive-banner-breadcrumbs a {
  color: var(--ndppc-primary-dark);
}

body[data-page="project-details"] .ndppc-project-archive-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.15vw, 2.2rem);
  line-height: 1.08;
}

body[data-page="project-details"] .ndppc-project-archive-shell {
  padding-top: 30px;
}

body[data-page="project-details"] .ndppc-project-archive-overview {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.9fr);
  gap: 1.2rem;
  margin-bottom: 1.55rem;
}

body[data-page="project-details"] .ndppc-project-archive-overview-copy {
  display: grid;
  gap: 0.95rem;
  align-content: start;
  padding: 1.45rem 1.5rem;
  border-radius: 28px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(71, 109, 140, 0.16), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 243, 233, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-overview-copy h2,
body[data-page="project-details"] .ndppc-project-archive-lane-head h3,
body[data-page="project-details"] .ndppc-project-archive-records-head h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
  line-height: 1.14;
}

body[data-page="project-details"] .ndppc-project-archive-overview-copy .ndppc-card-copy,
body[data-page="project-details"] .ndppc-project-archive-lane-head .ndppc-card-copy,
body[data-page="project-details"] .ndppc-project-archive-records-head .ndppc-card-copy,
body[data-page="project-details"] .ndppc-project-archive-record-card p {
  margin: 0;
  color: var(--ndppc-copy);
  line-height: 1.72;
  text-align: justify;
}

body[data-page="project-details"] .ndppc-project-archive-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  padding-top: 0.1rem;
}

body[data-page="project-details"] .ndppc-project-archive-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="project-details"] .ndppc-project-archive-metric {
  display: grid;
  gap: 0.3rem;
  align-content: start;
  min-height: 132px;
  padding: 1.05rem 1rem 0.95rem;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-metric-emerald {
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(233, 243, 237, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-metric-slate {
  background:
    radial-gradient(circle at top right, rgba(71, 109, 140, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(235, 241, 245, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-metric strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.8rem, 2.35vw, 2.35rem);
  line-height: 1;
}

body[data-page="project-details"] .ndppc-project-archive-metric span {
  color: var(--ndppc-copy);
  font-weight: 700;
}

body[data-page="project-details"] .ndppc-project-archive-lanes {
  display: grid;
  gap: 1.35rem;
}

body[data-page="project-details"] .ndppc-project-archive-lane {
  display: grid;
  gap: 1rem;
  padding: 1.35rem 1.35rem 1.25rem;
  border-radius: 28px;
  border: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="project-details"] .ndppc-project-archive-lane-ongoing {
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(234, 244, 238, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-lane-completed {
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.14), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 243, 233, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-lane-head {
  display: grid;
  gap: 0.45rem;
}

body[data-page="project-details"] .ndppc-project-archive-card-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="project-details"] .ndppc-project-archive-records-band {
  padding-top: 22px;
}

body[data-page="project-details"] .ndppc-project-archive-records-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: end;
  margin-bottom: 1.05rem;
}

body[data-page="project-details"] .ndppc-project-archive-records-grid {
  display: grid;
  gap: 1rem;
}

body[data-page="project-details"] .ndppc-project-archive-record-card {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 1.2rem 1.2rem 1.15rem;
  border-radius: 24px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(248, 244, 236, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-record-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 76px;
  border-radius: 20px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.76);
  color: var(--ndppc-primary-dark);
  font-size: 1.85rem;
  line-height: 1;
}

body[data-page="project-details"] .ndppc-project-archive-record-copy {
  display: grid;
  gap: 0.55rem;
}

body[data-page="project-details"] .ndppc-project-archive-record-card h4 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.1rem;
  line-height: 1.4;
}

@media (max-width: 1199px) {
  body[data-page="project-details"] .ndppc-project-archive-banner-copy {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body[data-page="project-details"] .ndppc-project-archive-overview,
  body[data-page="project-details"] .ndppc-project-archive-records-head {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991px) {
  body[data-page="project-details"] .ndppc-project-archive-banner-frame,
  body[data-page="project-details"] .ndppc-project-archive-banner-frame img {
    min-height: 102px;
  }

  body[data-page="project-details"] .ndppc-project-archive-metrics,
  body[data-page="project-details"] .ndppc-project-archive-card-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="project-details"] .ndppc-project-archive-record-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="project-details"] .ndppc-project-archive-banner-frame,
  body[data-page="project-details"] .ndppc-project-archive-banner-frame img {
    min-height: 88px;
  }

  body[data-page="project-details"] .ndppc-project-archive-banner-copy {
    padding: 0.75rem 1rem;
  }

  body[data-page="project-details"] .ndppc-project-archive-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="project-details"] .ndppc-project-archive-shell {
    padding-top: 22px;
  }

  body[data-page="project-details"] .ndppc-project-archive-overview-copy,
  body[data-page="project-details"] .ndppc-project-archive-lane,
  body[data-page="project-details"] .ndppc-project-archive-record-card {
    padding-left: 1rem;
    padding-right: 1rem;
  }
}

/* Final Project Archive Redesign Override */
body[data-page="project-details"] .banner.ndppc-project-archive-banner {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

body[data-page="project-details"] .ndppc-project-archive-shell {
  padding-top: 22px;
  padding-bottom: 26px;
}

body[data-page="project-details"] .banner.ndppc-project-archive-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="project-details"] .banner.ndppc-project-archive-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="project-details"] .banner_content.ndppc-project-archive-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="project-details"] .ndppc-project-archive-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="project-details"] .ndppc-project-archive-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="project-details"] .ndppc-project-archive-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="project-details"] .ndppc-project-archive-banner-copy {
  position: absolute;
  inset: 0;
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
  display: grid !important;
  gap: 1rem !important;
  align-content: center !important;
  justify-items: start !important;
  justify-content: start !important;
  text-align: left !important;
  padding-top: 1.45rem !important;
  padding-bottom: 1.45rem !important;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem)) !important;
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem)) !important;
  z-index: 2;
}

body[data-page="project-details"] .ndppc-project-archive-banner-breadcrumbs {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 0.45rem !important;
  margin-bottom: 0 !important;
  justify-content: flex-start !important;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="project-details"] .ndppc-project-archive-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="project-details"] .ndppc-project-archive-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.08;
}

body[data-page="project-details"] .ndppc-project-archive-overview,
body[data-page="project-details"] .ndppc-project-archive-current-band,
body[data-page="project-details"] .ndppc-project-archive-completed-band {
  border-radius: 30px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: none;
}

body[data-page="project-details"] .ndppc-project-archive-overview {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.95fr);
  gap: 1.2rem;
  margin-bottom: 1.35rem;
  padding: 1.35rem;
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.13), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(239, 246, 242, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-overview-copy {
  display: grid;
  align-content: start;
  gap: 0.7rem;
}

body[data-page="project-details"] .ndppc-project-archive-overview-copy h2,
body[data-page="project-details"] .ndppc-project-archive-section-head h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.66rem, 2.2vw, 2.24rem);
  line-height: 1.1;
}

body[data-page="project-details"] .ndppc-project-archive-threadline {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  margin-top: 0.15rem;
}

body[data-page="project-details"] .ndppc-project-archive-threadline span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0.2rem 0.8rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(20, 53, 38, 0.08);
  color: var(--ndppc-primary-dark);
  font-size: 0.8rem;
  font-weight: 700;
  line-height: 1.2;
}

body[data-page="project-details"] .ndppc-project-archive-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="project-details"] .ndppc-project-archive-metric {
  display: grid;
  align-content: end;
  gap: 0.25rem;
  min-height: 128px;
  padding: 1rem 1.05rem;
  border-radius: 22px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.82);
}

body[data-page="project-details"] .ndppc-project-archive-metric-emerald {
  background: linear-gradient(180deg, rgba(225, 241, 233, 0.98), rgba(242, 248, 245, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-metric-bronze {
  background: linear-gradient(180deg, rgba(248, 240, 222, 0.98), rgba(252, 248, 240, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-metric-slate {
  background: linear-gradient(180deg, rgba(228, 238, 243, 0.98), rgba(245, 249, 251, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-metric strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(2.05rem, 4vw, 2.55rem);
  line-height: 0.95;
}

body[data-page="project-details"] .ndppc-project-archive-metric span {
  color: var(--ndppc-copy-soft);
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="project-details"] .ndppc-project-archive-current-band,
body[data-page="project-details"] .ndppc-project-archive-completed-band {
  display: grid;
  gap: 1rem;
  margin-bottom: 1.35rem;
  padding: 1.35rem;
}

body[data-page="project-details"] .ndppc-project-archive-current-band {
  background:
    radial-gradient(circle at top right, rgba(76, 130, 99, 0.13), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(239, 246, 242, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-completed-band {
  background:
    radial-gradient(circle at top right, rgba(94, 127, 147, 0.11), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 248, 250, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-section-head {
  display: grid;
  gap: 0.45rem;
}

body[data-page="project-details"] .ndppc-project-archive-section-head .ndppc-card-copy,
body[data-page="project-details"] .ndppc-project-archive-overview-copy .ndppc-card-copy {
  margin: 0;
  color: var(--ndppc-copy);
  line-height: 1.7;
}

body[data-page="project-details"] .ndppc-project-archive-entry-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
}

body[data-page="project-details"] .ndppc-project-archive-entry {
  display: grid;
  grid-template-columns: 152px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 1.2rem;
  border-radius: 24px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.84);
}

body[data-page="project-details"] .ndppc-project-archive-entry-featured {
  grid-template-columns: 176px minmax(0, 1fr);
  padding: 1.3rem;
}

body[data-page="project-details"] .ndppc-project-archive-entry-tone-emerald {
  background: linear-gradient(180deg, rgba(245, 250, 247, 0.99), rgba(236, 246, 241, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-entry-tone-bronze {
  background: linear-gradient(180deg, rgba(252, 248, 241, 0.99), rgba(247, 241, 229, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-entry-tone-slate {
  background: linear-gradient(180deg, rgba(248, 250, 251, 0.99), rgba(239, 245, 248, 0.98));
}

body[data-page="project-details"] .ndppc-project-archive-entry-rail {
  display: grid;
  gap: 0.7rem;
  align-content: start;
  min-height: 100%;
  padding-right: 0.95rem;
  border-right: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="project-details"] .ndppc-project-archive-entry-code {
  color: var(--ndppc-primary-dark);
  font-size: 1.8rem;
  font-weight: 800;
  line-height: 1;
  letter-spacing: 0.03em;
}

body[data-page="project-details"] .ndppc-project-archive-entry-programme {
  color: var(--ndppc-copy-soft);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1.55;
}

body[data-page="project-details"] .ndppc-project-archive-entry-main {
  display: grid;
  gap: 0.9rem;
}

body[data-page="project-details"] .ndppc-project-archive-entry h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.14rem;
  line-height: 1.5;
}

body[data-page="project-details"] .ndppc-project-archive-entry-facts {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.7rem;
}

body[data-page="project-details"] .ndppc-project-archive-entry-facts article {
  display: grid;
  gap: 0.22rem;
  min-height: 72px;
  padding: 0.8rem 0.9rem;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="project-details"] .ndppc-project-archive-entry-facts span {
  color: var(--ndppc-copy-soft);
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="project-details"] .ndppc-project-archive-entry-facts strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.94rem;
  line-height: 1.45;
}

body[data-page="project-details"] .ndppc-project-archive-entry-objectives,
body[data-page="project-details"] .ndppc-project-archive-entry-drawer {
  border-radius: 20px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.76);
}

body[data-page="project-details"] .ndppc-project-archive-entry-objectives-open {
  padding: 0.95rem 1rem;
}

body[data-page="project-details"] .ndppc-project-archive-entry-objectives > strong {
  color: var(--ndppc-primary-dark);
}

body[data-page="project-details"] .ndppc-project-archive-entry-drawer summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  padding: 0.9rem 1rem;
  cursor: pointer;
  list-style: none;
  color: var(--ndppc-primary-dark);
  font-weight: 700;
}

body[data-page="project-details"] .ndppc-project-archive-entry-drawer summary::-webkit-details-marker {
  display: none;
}

body[data-page="project-details"] .ndppc-project-archive-entry-drawer summary strong {
  font-size: 0.9rem;
}

body[data-page="project-details"] .ndppc-project-archive-entry-drawer[open] summary {
  border-bottom: 1px solid rgba(20, 53, 38, 0.08);
}

body[data-page="project-details"] .ndppc-project-archive-entry-drawer .ndppc-project-archive-entry-objectives {
  border: 0;
  border-radius: 0 0 20px 20px;
  background: transparent;
  padding: 0.95rem 1rem;
}

body[data-page="project-details"] .ndppc-project-archive-entry-objectives ul {
  margin: 0.15rem 0 0;
  padding: 0;
  list-style: none;
  color: var(--ndppc-copy);
}

body[data-page="project-details"] .ndppc-project-archive-entry-objectives li {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 0.45rem;
  align-items: start;
  margin: 0 0 0.5rem;
  line-height: 1.68;
}

body[data-page="project-details"] .ndppc-project-archive-entry-objectives li .material-symbols-outlined {
  font-size: 1.1rem;
  line-height: 1.2;
  color: var(--ndppc-accent);
}

body[data-page="project-details"] .ndppc-project-archive-entry-objectives li:last-child {
  margin-bottom: 0;
}

body[data-page="project-details"] .ndppc-project-archive-entry-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

body[data-page="project-details"] .ndppc-project-archive-entry-tags span {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0.2rem 0.7rem;
  border-radius: 999px;
  border: 1px solid rgba(20, 53, 38, 0.08);
  background: rgba(255, 255, 255, 0.72);
  color: var(--ndppc-primary-dark);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.2;
}

@media (max-width: 1199px) {
  body[data-page="project-details"] .ndppc-project-archive-overview {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991px) {
  body[data-page="project-details"] .ndppc-project-archive-banner-frame,
  body[data-page="project-details"] .ndppc-project-archive-banner-frame img {
    min-height: 102px;
  }

  body[data-page="project-details"] .ndppc-project-archive-entry,
  body[data-page="project-details"] .ndppc-project-archive-entry-featured {
    grid-template-columns: 1fr;
  }

  body[data-page="project-details"] .ndppc-project-archive-entry-rail {
    padding-right: 0;
    padding-bottom: 0.8rem;
    border-right: 0;
    border-bottom: 1px solid rgba(20, 53, 38, 0.08);
  }

  body[data-page="project-details"] .ndppc-project-archive-entry-facts {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="project-details"] .ndppc-project-archive-banner-frame,
  body[data-page="project-details"] .ndppc-project-archive-banner-frame img {
    min-height: 88px;
  }

  body[data-page="project-details"] .ndppc-project-archive-banner-copy {
    gap: 0.4rem !important;
    padding-top: 0.65rem !important;
    padding-bottom: 0.65rem !important;
    padding-left: 1.1rem !important;
    padding-right: 1.1rem !important;
  }

  body[data-page="project-details"] .ndppc-project-archive-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="project-details"] .ndppc-project-archive-overview,
  body[data-page="project-details"] .ndppc-project-archive-current-band,
  body[data-page="project-details"] .ndppc-project-archive-completed-band {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body[data-page="project-details"] .ndppc-project-archive-metrics {
    grid-template-columns: 1fr;
  }

  body[data-page="project-details"] .ndppc-project-archive-entry {
    padding: 1rem;
  }
}

/* Final PG Research Page */
body[data-page="pg"] .ndppc-shell {
  padding-top: 28px;
  padding-bottom: 28px;
}

body[data-page="pg"] .ndppc-pg-page-shell {
  padding-top: 20px;
  padding-bottom: 18px;
}

body[data-page="pg"] .ndppc-pg-overview {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, 0.85fr);
  gap: 1.25rem;
  align-items: stretch;
}

body[data-page="pg"] .ndppc-pg-overview-copy,
body[data-page="pg"] .ndppc-pg-stat-grid {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(244, 239, 228, 0.95));
  border: 1px solid rgba(139, 100, 20, 0.12);
  border-radius: 28px;
  padding: 1.5rem 1.6rem;
}

body[data-page="pg"] .ndppc-pg-overview-copy h2 {
  margin: 0.85rem 0 0.8rem;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.85rem, 2.55vw, 2.7rem);
  line-height: 1.08;
}

body[data-page="pg"] .ndppc-pg-overview-copy p {
  margin: 0;
  color: #425a66;
  font-size: 1.02rem;
  line-height: 1.8;
  text-align: justify;
}

body[data-page="pg"] .ndppc-pg-tag-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  margin-top: 1.15rem;
}

body[data-page="pg"] .ndppc-pg-tag-row span,
body[data-page="pg"] .ndppc-pg-alumni-strip span {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 0.55rem 1rem;
  border-radius: 999px;
  background: rgba(243, 236, 218, 0.9);
  border: 1px solid rgba(139, 100, 20, 0.14);
  color: #6f5720;
  font-weight: 600;
}

body[data-page="pg"] .ndppc-pg-stat-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.9rem;
}

body[data-page="pg"] .ndppc-pg-stat {
  min-height: 118px;
  border-radius: 22px;
  padding: 1rem 1.1rem;
  background: linear-gradient(135deg, rgba(232, 243, 238, 0.95), rgba(246, 241, 229, 0.98));
  border: 1px solid rgba(24, 71, 52, 0.12);
  display: grid;
  align-content: center;
  gap: 0.35rem;
}

body[data-page="pg"] .ndppc-pg-stat strong {
  font-size: 2rem;
  line-height: 1;
  color: var(--ndppc-primary-dark);
}

body[data-page="pg"] .ndppc-pg-stat span {
  color: #5b6672;
  font-weight: 600;
  line-height: 1.45;
}

body[data-page="pg"] .ndppc-pg-card-grid,
body[data-page="pg"] .ndppc-pg-doctoral-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.15rem;
}

body[data-page="pg"] .ndppc-pg-current-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg-card,
body[data-page="pg"] .ndppc-pg-record,
body[data-page="pg"] .ndppc-pg-current-card {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 239, 228, 0.95));
  border: 1px solid rgba(139, 100, 20, 0.12);
  border-radius: 28px;
  padding: 1.35rem 1.4rem;
}

body[data-page="pg"] .ndppc-pg-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
  margin-bottom: 0.85rem;
}

body[data-page="pg"] .ndppc-pg-card-top strong {
  color: #6b7683;
  font-size: 0.9rem;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg-card h3,
body[data-page="pg"] .ndppc-pg-record h3,
body[data-page="pg"] .ndppc-pg-current-card h3 {
  margin: 0 0 0.45rem;
  color: var(--ndppc-primary-dark);
  font-size: 1.38rem;
  line-height: 1.2;
}

body[data-page="pg"] .ndppc-pg-role {
  margin: 0 0 0.9rem;
  color: #8b6414;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg-meta-list,
body[data-page="pg"] .ndppc-pg-objectives {
  margin: 0;
  padding-left: 1.15rem;
  color: #465764;
}

body[data-page="pg"] .ndppc-pg-meta-list li,
body[data-page="pg"] .ndppc-pg-objectives li {
  margin-bottom: 0.55rem;
  line-height: 1.7;
}

body[data-page="pg"] .ndppc-pg-alumni-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem;
  margin-bottom: 1.15rem;
}

body[data-page="pg"] .ndppc-pg-current-card p {
  margin: 0;
  color: #4a5b67;
  line-height: 1.75;
  text-align: justify;
}

@media (max-width: 1199px) {
  body[data-page="pg"] .ndppc-pg-overview,
  body[data-page="pg"] .ndppc-pg-card-grid,
  body[data-page="pg"] .ndppc-pg-doctoral-grid,
  body[data-page="pg"] .ndppc-pg-current-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="pg"] .ndppc-pg-overview-copy,
  body[data-page="pg"] .ndppc-pg-stat-grid,
  body[data-page="pg"] .ndppc-pg-card,
  body[data-page="pg"] .ndppc-pg-record,
  body[data-page="pg"] .ndppc-pg-current-card {
    border-radius: 22px;
    padding: 1.1rem 1rem;
  }

  body[data-page="pg"] .ndppc-pg-overview-copy h2 {
    font-size: 1.75rem;
  }

  body[data-page="pg"] .ndppc-pg-card-top {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Final PG Redesign */
body[data-page="pg"] .banner.ndppc-pg-banner {
  padding-top: 0;
  margin-top: 0;
  padding-bottom: 0;
}

body[data-page="pg"] .ndppc-pg-banner-grid,
body[data-page="pg"] .banner.ndppc-pg-banner .banner_content {
  width: 100%;
  max-width: none;
  margin: 0;
}

body[data-page="pg"] .ndppc-pg-banner-frame {
  position: relative;
  margin: 0;
  min-height: clamp(280px, 29vw, 400px);
  border-radius: 0;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(340px, 0.85fr);
  background:
    radial-gradient(circle at top right, rgba(255, 255, 255, 0.22), transparent 28%),
    linear-gradient(110deg, rgba(12, 40, 30, 0.94) 0%, rgba(27, 73, 54, 0.88) 42%, rgba(86, 71, 34, 0.76) 100%);
}

body[data-page="pg"] .ndppc-pg-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(8, 22, 17, 0.78) 0%, rgba(8, 22, 17, 0.5) 40%, rgba(8, 22, 17, 0.14) 100%),
    url("../img/Pheno2/12.jpg") center/cover no-repeat;
  mix-blend-mode: screen;
  opacity: 0.34;
}

body[data-page="pg"] .ndppc-pg-banner-copy,
body[data-page="pg"] .ndppc-pg-banner-gallery {
  position: relative;
  z-index: 1;
}

body[data-page="pg"] .ndppc-pg-banner-copy {
  padding: 1.7rem 1.7rem 1.55rem;
  color: #fff;
  display: grid;
  align-content: center;
  gap: 0.9rem;
}

body[data-page="pg"] .ndppc-pg-banner-copy .ndppc-breadcrumbs,
body[data-page="pg"] .ndppc-pg-banner-copy .ndppc-breadcrumbs a {
  color: rgba(255, 255, 255, 0.88);
}

body[data-page="pg"] .ndppc-pg-banner-copy .rounded-pill {
  width: fit-content;
  min-height: 40px;
  padding: 0.55rem 1rem;
  border: 1px solid rgba(255, 255, 255, 0.16);
  background: rgba(255, 255, 255, 0.12);
  color: #fff0ce;
}

body[data-page="pg"] .ndppc-pg-banner-copy h1 {
  margin: 0;
  max-width: 15ch;
  color: #fff;
  font-size: clamp(2.15rem, 3.2vw, 3.45rem);
  line-height: 0.98;
}

body[data-page="pg"] .ndppc-pg-banner-copy p {
  margin: 0;
  max-width: 58ch;
  color: rgba(255, 255, 255, 0.9);
  font-size: 1rem;
  line-height: 1.8;
}

body[data-page="pg"] .ndppc-pg-banner-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

body[data-page="pg"] .ndppc-pg-banner-pills span {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0.5rem 0.95rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: #fff;
  font-weight: 600;
}

body[data-page="pg"] .ndppc-pg-banner-gallery {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.9rem;
  align-content: center;
  padding: 1.35rem 1.35rem 1.25rem 0;
}

body[data-page="pg"] .ndppc-pg-banner-card {
  display: grid;
  grid-template-columns: 92px 1fr;
  gap: 0.85rem;
  align-items: center;
  padding: 0.85rem;
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(255, 255, 255, 0.24);
  box-shadow: 0 20px 40px rgba(6, 20, 16, 0.12);
}

body[data-page="pg"] .ndppc-pg-banner-card.is-primary {
  grid-column: span 2;
}

body[data-page="pg"] .ndppc-pg-banner-card img {
  width: 92px;
  height: 108px;
  object-fit: cover;
  border-radius: 22px;
}

body[data-page="pg"] .ndppc-pg-banner-card strong {
  display: block;
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.25;
}

body[data-page="pg"] .ndppc-pg-banner-card span {
  display: block;
  margin-top: 0.3rem;
  color: #5d6b78;
  line-height: 1.45;
}

body[data-page="pg"] .ndppc-pg-page-shell {
  padding-top: 18px;
  padding-bottom: 12px;
}

body[data-page="pg"] .ndppc-pg-summary-band {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg-summary-card {
  min-height: 154px;
  padding: 1.2rem 1.25rem;
  border-radius: 28px;
  border: 1px solid rgba(139, 100, 20, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 239, 228, 0.95));
  display: grid;
  align-content: center;
  justify-items: center;
  text-align: center;
  gap: 0.35rem;
}

body[data-page="pg"] .ndppc-pg-summary-card i {
  font-size: 1.35rem;
  color: #8b6414;
}

body[data-page="pg"] .ndppc-pg-summary-card strong {
  color: var(--ndppc-primary-dark);
  font-size: 2rem;
  line-height: 1;
}

body[data-page="pg"] .ndppc-pg-summary-card span {
  color: #586774;
  font-weight: 600;
  line-height: 1.55;
}

body[data-page="pg"] .ndppc-pg-training-layout,
body[data-page="pg"] .ndppc-pg-alumni-layout,
body[data-page="pg"] .ndppc-pg-current-layout {
  display: grid;
  gap: 1.15rem;
}

body[data-page="pg"] .ndppc-pg-training-layout {
  grid-template-columns: minmax(260px, 0.72fr) minmax(0, 1.28fr);
}

body[data-page="pg"] .ndppc-pg-side-note {
  border-radius: 28px;
  padding: 1.4rem 1.35rem;
  background: linear-gradient(135deg, rgba(17, 55, 41, 0.96), rgba(48, 80, 58, 0.92));
  color: #fff;
  display: grid;
  align-content: start;
  gap: 0.8rem;
}

body[data-page="pg"] .ndppc-pg-side-note .rounded-pill {
  width: fit-content;
  background: rgba(255, 255, 255, 0.12);
  color: #fff0ce;
  border: 1px solid rgba(255, 255, 255, 0.14);
}

body[data-page="pg"] .ndppc-pg-side-note h3 {
  margin: 0;
  color: #fff;
  font-size: 1.55rem;
  line-height: 1.15;
}

body[data-page="pg"] .ndppc-pg-side-note p {
  margin: 0;
  color: rgba(255, 255, 255, 0.88);
  line-height: 1.8;
  text-align: justify;
}

body[data-page="pg"] .ndppc-pg-card-grid,
body[data-page="pg"] .ndppc-pg-doctoral-grid,
body[data-page="pg"] .ndppc-pg-current-grid {
  display: grid;
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg-card-grid {
  grid-template-columns: 1fr;
}

body[data-page="pg"] .ndppc-pg-card,
body[data-page="pg"] .ndppc-pg-record,
body[data-page="pg"] .ndppc-pg-current-card {
  border-radius: 28px;
  padding: 1.2rem 1.2rem 1.15rem;
  border: 1px solid rgba(139, 100, 20, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 239, 228, 0.95));
}

body[data-page="pg"] .ndppc-pg-card {
  display: grid;
  grid-template-columns: 66px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

body[data-page="pg"] .ndppc-pg-card-icon {
  width: 66px;
  height: 66px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(226, 241, 233, 0.98), rgba(244, 239, 228, 0.98));
  color: #215b3f;
  font-size: 1.35rem;
}

body[data-page="pg"] .ndppc-pg-card-body {
  min-width: 0;
}

body[data-page="pg"] .ndppc-pg-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  margin-bottom: 0.8rem;
}

body[data-page="pg"] .ndppc-pg-card-top strong {
  color: #6c7683;
  font-size: 0.9rem;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg-card h3,
body[data-page="pg"] .ndppc-pg-record h3,
body[data-page="pg"] .ndppc-pg-current-card h3,
body[data-page="pg"] .ndppc-pg-alumni-panel h3 {
  margin: 0 0 0.45rem;
  color: var(--ndppc-primary-dark);
  font-size: 1.38rem;
  line-height: 1.2;
}

body[data-page="pg"] .ndppc-pg-role {
  margin: 0 0 0.85rem;
  color: #8b6414;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg-meta-list,
body[data-page="pg"] .ndppc-pg-objectives {
  margin: 0;
  padding-left: 1.05rem;
  color: #465764;
}

body[data-page="pg"] .ndppc-pg-meta-list li,
body[data-page="pg"] .ndppc-pg-objectives li {
  margin-bottom: 0.5rem;
  line-height: 1.72;
}

body[data-page="pg"] .ndppc-pg-alumni-layout,
body[data-page="pg"] .ndppc-pg-current-layout {
  grid-template-columns: minmax(300px, 0.92fr) minmax(0, 1.08fr);
  align-items: start;
}

body[data-page="pg"] .ndppc-pg-photo-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="pg"] .ndppc-pg-photo-grid-scholars {
  grid-template-columns: 1fr;
}

body[data-page="pg"] .ndppc-pg-photo-card {
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(139, 100, 20, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 239, 228, 0.95));
}

body[data-page="pg"] .ndppc-pg-photo-card img {
  width: 100%;
  height: 250px;
  object-fit: cover;
  object-position: center top;
  display: block;
}

body[data-page="pg"] .ndppc-pg-photo-card div {
  padding: 0.95rem 1rem 1rem;
}

body[data-page="pg"] .ndppc-pg-photo-card strong {
  display: block;
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
  line-height: 1.25;
}

body[data-page="pg"] .ndppc-pg-photo-card span {
  display: block;
  margin-top: 0.25rem;
  color: #64717e;
  line-height: 1.5;
}

body[data-page="pg"] .ndppc-pg-current-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page="pg"] .ndppc-pg-current-card p {
  margin: 0;
  color: #4b5c68;
  line-height: 1.75;
  text-align: justify;
}

body[data-page="pg"] .ndppc-pg-alumni-strip {
  display: none;
}

@media (max-width: 1199px) {
  body[data-page="pg"] .ndppc-pg-banner-frame,
  body[data-page="pg"] .ndppc-pg-training-layout,
  body[data-page="pg"] .ndppc-pg-alumni-layout,
  body[data-page="pg"] .ndppc-pg-current-layout,
  body[data-page="pg"] .ndppc-pg-summary-band,
  body[data-page="pg"] .ndppc-pg-current-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pg-banner-gallery {
    padding: 0 1.2rem 1.2rem;
  }

  body[data-page="pg"] .ndppc-pg-photo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body[data-page="pg"] .ndppc-pg-banner-frame {
    min-height: 0;
  }

  body[data-page="pg"] .ndppc-pg-banner-copy {
    padding: 1.15rem 1rem 0.95rem;
  }

  body[data-page="pg"] .ndppc-pg-banner-copy h1 {
    max-width: none;
    font-size: 1.9rem;
  }

  body[data-page="pg"] .ndppc-pg-banner-gallery,
  body[data-page="pg"] .ndppc-pg-photo-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pg-banner-card.is-primary {
    grid-column: span 1;
  }
}

@media (max-width: 767px) {
  body[data-page="pg"] .ndppc-pg-banner-card {
    grid-template-columns: 72px 1fr;
    border-radius: 22px;
  }

  body[data-page="pg"] .ndppc-pg-banner-card img {
    width: 72px;
    height: 86px;
    border-radius: 16px;
  }

  body[data-page="pg"] .ndppc-pg-summary-card,
  body[data-page="pg"] .ndppc-pg-side-note,
  body[data-page="pg"] .ndppc-pg-card,
  body[data-page="pg"] .ndppc-pg-record,
  body[data-page="pg"] .ndppc-pg-current-card,
  body[data-page="pg"] .ndppc-pg-photo-card {
    border-radius: 22px;
  }

  body[data-page="pg"] .ndppc-pg-card {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pg-card-top {
    flex-direction: column;
    align-items: flex-start;
  }

  body[data-page="pg"] .ndppc-pg-photo-card img {
    height: 210px;
  }
}

/* Final PG Banner Sync */
body[data-page="pg"] .banner.ndppc-pg-banner {
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
}

body[data-page="pg"] .banner.ndppc-pg-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="pg"] .banner.ndppc-pg-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="pg"] .banner_content.ndppc-pg-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="pg"] .ndppc-pg-banner-frame {
  position: relative;
  width: 100%;
  min-height: clamp(250px, 25vw, 330px);
  margin: 0;
  overflow: hidden;
  display: block;
  background: transparent;
}

body[data-page="pg"] .ndppc-pg-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: clamp(250px, 25vw, 330px);
  display: block;
  object-fit: cover;
  object-position: center 42%;
}

body[data-page="pg"] .ndppc-pg-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(12, 34, 26, 0.88) 0%, rgba(12, 34, 26, 0.74) 30%, rgba(27, 57, 43, 0.44) 58%, rgba(27, 57, 43, 0.12) 100%),
    linear-gradient(180deg, rgba(176, 139, 57, 0.14), rgba(176, 139, 57, 0));
  z-index: 1;
}

body[data-page="pg"] .ndppc-pg-banner-copy {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: grid;
  gap: 0.85rem;
  width: 100%;
  max-width: none;
  margin: 0;
  align-content: center;
  padding-top: 1.35rem;
  padding-bottom: 1.35rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
}

body[data-page="pg"] .ndppc-pg-banner-breadcrumbs,
body[data-page="pg"] .ndppc-pg-banner-breadcrumbs a {
  color: rgba(255, 255, 255, 0.82);
}

body[data-page="pg"] .ndppc-pg-banner-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 38px;
  padding: 0.45rem 0.95rem;
  border-radius: 999px;
  background: rgba(243, 236, 218, 0.14);
  border: 1px solid rgba(243, 236, 218, 0.18);
  color: #f3dfaa;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="pg"] .ndppc-pg-banner-copy h1 {
  margin: 0;
  max-width: 18ch;
  color: #fff;
  font-size: clamp(2rem, 3.1vw, 3.15rem);
  line-height: 1.02;
}

body[data-page="pg"] .ndppc-pg-banner-copy p {
  margin: 0;
  max-width: 66ch;
  color: rgba(255, 255, 255, 0.9);
  line-height: 1.75;
}

body[data-page="pg"] .ndppc-pg-banner-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 190px));
  gap: 0.8rem;
  margin-top: 0.2rem;
}

body[data-page="pg"] .ndppc-pg-banner-metrics article {
  min-height: 94px;
  padding: 0.9rem 1rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(8px);
  display: grid;
  align-content: center;
  gap: 0.2rem;
}

body[data-page="pg"] .ndppc-pg-banner-metrics strong {
  color: #fff;
  font-size: 1.7rem;
  line-height: 1;
}

body[data-page="pg"] .ndppc-pg-banner-metrics span {
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.93rem;
  line-height: 1.45;
  font-weight: 600;
}

@media (max-width: 991px) {
  body[data-page="pg"] .ndppc-pg-banner-frame,
  body[data-page="pg"] .ndppc-pg-banner-frame img {
    min-height: 210px;
  }

  body[data-page="pg"] .ndppc-pg-banner-copy {
    padding-top: 1rem;
    padding-bottom: 1rem;
  }

  body[data-page="pg"] .ndppc-pg-banner-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  body[data-page="pg"] .ndppc-pg-banner-frame,
  body[data-page="pg"] .ndppc-pg-banner-frame img {
    min-height: 230px;
  }

  body[data-page="pg"] .ndppc-pg-banner-copy {
    padding-top: 0.75rem;
    padding-bottom: 0.75rem;
    padding-left: max(1rem, calc((100vw - 1320px) / 2 + 0.75rem));
    padding-right: max(1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  }

  body[data-page="pg"] .ndppc-pg-banner-copy h1 {
    font-size: 1.75rem;
    max-width: none;
  }

  body[data-page="pg"] .ndppc-pg-banner-copy p {
    line-height: 1.6;
  }

  body[data-page="pg"] .ndppc-pg-banner-metrics {
    grid-template-columns: 1fr;
  }
}

/* Final PGX Rebuild */
body[data-page="pg"] .banner.ndppc-pgx-banner {
  padding-top: 0;
  padding-bottom: 0;
  margin-top: 0;
}

body[data-page="pg"] .banner.ndppc-pgx-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="pg"] .banner.ndppc-pgx-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="pg"] .banner_content.ndppc-pgx-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="pg"] .ndppc-pgx-banner-frame {
  position: relative;
  width: 100%;
  min-height: clamp(280px, 27vw, 360px);
  margin: 0;
  overflow: hidden;
}

body[data-page="pg"] .ndppc-pgx-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: clamp(280px, 27vw, 360px);
  display: block;
  object-fit: cover;
  object-position: center 42%;
}

body[data-page="pg"] .ndppc-pgx-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(11, 32, 24, 0.9) 0%, rgba(11, 32, 24, 0.8) 28%, rgba(19, 49, 37, 0.45) 56%, rgba(19, 49, 37, 0.12) 100%),
    linear-gradient(180deg, rgba(199, 164, 92, 0.15), rgba(199, 164, 92, 0));
  z-index: 1;
}

body[data-page="pg"] .ndppc-pgx-banner-copy {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: grid;
  align-content: center;
  justify-items: center;
  text-align: center;
  gap: 0.8rem;
  width: 100%;
  max-width: none;
  margin: 0;
  padding-top: 1.35rem;
  padding-bottom: 1.35rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
}

body[data-page="pg"] .ndppc-pgx-banner-breadcrumbs,
body[data-page="pg"] .ndppc-pgx-banner-breadcrumbs a {
  color: rgba(255, 255, 255, 0.82);
}

body[data-page="pg"] .ndppc-pgx-banner-kicker {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 38px;
  padding: 0.45rem 0.9rem;
  border-radius: 999px;
  background: rgba(243, 236, 218, 0.14);
  border: 1px solid rgba(243, 236, 218, 0.18);
  color: #f3dfaa;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

body[data-page="pg"] .ndppc-pgx-banner-copy h1 {
  margin: 0;
  max-width: none;
  color: #fff;
  font-size: clamp(1.55rem, 2vw, 2.2rem);
  line-height: 1.02;
}

body[data-page="pg"] .ndppc-pgx-overview-band {
  padding-top: 20px;
  padding-bottom: 20px;
}

body[data-page="pg"] .ndppc-pgx-mode-grid {
  border-radius: 30px;
  border: 1px solid rgba(139, 100, 20, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 239, 228, 0.95));
}

body[data-page="pg"] .ndppc-pgx-mode-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
}

body[data-page="pg"] .ndppc-pgx-mode-grid-full {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

body[data-page="pg"] .ndppc-pgx-mode-card {
  min-height: 148px;
  padding: 1.15rem 1.1rem;
  background: rgba(255, 255, 255, 0.72);
  display: grid;
  align-content: center;
  gap: 0.35rem;
}

body[data-page="pg"] .ndppc-pgx-mode-card i {
  color: #8b6414;
  font-size: 1.25rem;
}

body[data-page="pg"] .ndppc-pgx-mode-card strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.02rem;
  line-height: 1.25;
}

body[data-page="pg"] .ndppc-pgx-mode-card span {
  color: #5f6d7a;
  line-height: 1.55;
}

body[data-page="pg"] .ndppc-pgx-section-head {
  display: grid;
  gap: 0.65rem;
  margin-bottom: 1rem;
}

body[data-page="pg"] .ndppc-pgx-section-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.65rem, 2.2vw, 2.25rem);
  line-height: 1.12;
}

body[data-page="pg"] .ndppc-pgx-section-head p {
  margin: 0;
  max-width: 78ch;
  color: #55646f;
  line-height: 1.75;
  text-align: justify;
}

body[data-page="pg"] .ndppc-pgx-training-grid,
body[data-page="pg"] .ndppc-pgx-thesis-grid,
body[data-page="pg"] .ndppc-pgx-record-grid {
  display: grid;
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pgx-training-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

body[data-page="pg"] .ndppc-pgx-training-card,
body[data-page="pg"] .ndppc-pgx-record-card {
  padding: 1.15rem 1.2rem 1.1rem;
  border-radius: 28px;
  border: 1px solid rgba(139, 100, 20, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 239, 228, 0.95));
}

body[data-page="pg"] .ndppc-pgx-training-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  margin-bottom: 0.9rem;
}

body[data-page="pg"] .ndppc-pgx-training-top strong {
  color: #6c7683;
  font-size: 0.9rem;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pgx-training-core {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr);
  gap: 0.9rem;
  align-items: start;
  margin-bottom: 0.85rem;
}

body[data-page="pg"] .ndppc-pgx-training-icon {
  width: 62px;
  height: 62px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(226, 241, 233, 0.98), rgba(244, 239, 228, 0.98));
  color: #215b3f;
  font-size: 1.25rem;
}

body[data-page="pg"] .ndppc-pgx-training-copy h3,
body[data-page="pg"] .ndppc-pgx-record-card h3 {
  margin: 0 0 0.35rem;
  color: var(--ndppc-primary-dark);
  font-size: 1.28rem;
  line-height: 1.2;
}

body[data-page="pg"] .ndppc-pgx-role {
  margin: 0;
  color: #8b6414;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pgx-meta-list,
body[data-page="pg"] .ndppc-pgx-objectives {
  margin: 0;
  padding-left: 1.05rem;
  color: #475865;
}

body[data-page="pg"] .ndppc-pgx-meta-list li,
body[data-page="pg"] .ndppc-pgx-objectives li {
  margin-bottom: 0.5rem;
  line-height: 1.7;
}

body[data-page="pg"] .ndppc-pgx-alumni-layout,
body[data-page="pg"] .ndppc-pgx-current-layout {
  display: grid;
  grid-template-columns: minmax(300px, 0.86fr) minmax(0, 1.14fr);
  gap: 1rem;
  align-items: start;
}

body[data-page="pg"] .ndppc-pgx-combined-grid {
  display: grid;
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pgx-alumni-card {
  display: grid;
  grid-template-columns: minmax(250px, 0.78fr) minmax(0, 1.22fr);
  border-radius: 30px;
  overflow: hidden;
  border: 1px solid rgba(139, 100, 20, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 239, 228, 0.95));
}

body[data-page="pg"] .ndppc-pgx-alumni-photo {
  margin: 0;
  min-height: 100%;
}

body[data-page="pg"] .ndppc-pgx-alumni-photo img {
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
  object-position: center top;
  display: block;
}

body[data-page="pg"] .ndppc-pgx-alumni-copy {
  padding: 1.15rem 1.2rem 1.2rem;
  display: grid;
  align-content: start;
  gap: 0.9rem;
}

body[data-page="pg"] .ndppc-pgx-alumni-copy > p {
  margin: 0;
  color: #4a5b67;
  line-height: 1.75;
  text-align: justify;
}

body[data-page="pg"] .ndppc-pgx-face-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="pg"] .ndppc-pgx-face-grid-scholars {
  grid-template-columns: 1fr;
}

body[data-page="pg"] .ndppc-pgx-face-card {
  border-radius: 26px;
  overflow: hidden;
  border: 1px solid rgba(139, 100, 20, 0.12);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(244, 239, 228, 0.95));
}

body[data-page="pg"] .ndppc-pgx-face-card img {
  width: 100%;
  height: 240px;
  object-fit: cover;
  object-position: center top;
  display: block;
}

body[data-page="pg"] .ndppc-pgx-face-card div {
  padding: 0.9rem 1rem 1rem;
}

body[data-page="pg"] .ndppc-pgx-face-card strong {
  display: block;
  color: var(--ndppc-primary-dark);
  line-height: 1.25;
}

body[data-page="pg"] .ndppc-pgx-face-card span {
  display: block;
  margin-top: 0.25rem;
  color: #63707d;
  line-height: 1.5;
}

body[data-page="pg"] .ndppc-pgx-thesis-grid {
  grid-template-columns: 1fr;
}

body[data-page="pg"] .ndppc-pgx-record-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

body[data-page="pg"] .ndppc-pgx-record-card p {
  margin: 0;
  color: #4a5b67;
  line-height: 1.75;
  text-align: justify;
}

@media (max-width: 1199px) {
  body[data-page="pg"] .ndppc-pgx-training-grid,
  body[data-page="pg"] .ndppc-pgx-current-layout,
  body[data-page="pg"] .ndppc-pgx-record-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pgx-alumni-card {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pgx-mode-grid-full {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="pg"] .ndppc-pgx-face-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 991px) {
  body[data-page="pg"] .ndppc-pgx-banner-frame,
  body[data-page="pg"] .ndppc-pgx-banner-frame img {
    min-height: 240px;
  }

  body[data-page="pg"] .ndppc-pgx-banner-copy {
    padding-top: 1rem;
    padding-bottom: 1rem;
    justify-items: start;
    text-align: left;
  }

  body[data-page="pg"] .ndppc-pgx-face-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="pg"] .ndppc-pgx-mode-grid-full {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="pg"] .ndppc-pgx-banner-frame,
  body[data-page="pg"] .ndppc-pgx-banner-frame img {
    min-height: 270px;
  }

  body[data-page="pg"] .ndppc-pgx-banner-copy {
    padding-top: 0.85rem;
    padding-bottom: 0.85rem;
    padding-left: max(1rem, calc((100vw - 1320px) / 2 + 0.75rem));
    padding-right: max(1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  }

  body[data-page="pg"] .ndppc-pgx-banner-copy h1 {
    max-width: none;
    font-size: 1.85rem;
    white-space: normal;
  }

  body[data-page="pg"] .ndppc-pgx-alumni-photo img {
    min-height: 260px;
  }

  body[data-page="pg"] .ndppc-pgx-face-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pgx-training-top {
    flex-direction: column;
    align-items: flex-start;
  }

  body[data-page="pg"] .ndppc-pgx-training-core {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pgx-face-card img {
    height: 210px;
  }
}

@media (min-width: 992px) {
  body[data-page="pg"] .ndppc-pgx-banner-copy h1 {
    white-space: nowrap;
  }
}

/* Final PG Banner Like About */
body[data-page="pg"] .banner.ndppc-pgx-banner {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

body[data-page="pg"] .banner.ndppc-pgx-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="pg"] .banner.ndppc-pgx-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="pg"] .banner_content.ndppc-pgx-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="pg"] .ndppc-pgx-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="pg"] .ndppc-pgx-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="pg"] .ndppc-pgx-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="pg"] .ndppc-pgx-banner-copy {
  display: grid;
  gap: 1rem;
  width: 100%;
  max-width: none;
  margin: 0;
  position: absolute;
  inset: 0;
  align-content: center;
  justify-items: start;
  text-align: left;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="pg"] .ndppc-pgx-banner-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="pg"] .ndppc-pgx-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="pg"] .ndppc-pgx-banner-kicker {
  display: none;
}

body[data-page="pg"] .ndppc-pgx-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.08;
  max-width: none;
  white-space: normal;
}

@media (max-width: 991px) {
  body[data-page="pg"] .ndppc-pgx-banner-frame,
  body[data-page="pg"] .ndppc-pgx-banner-frame img {
    min-height: 102px;
    max-height: 102px;
  }
}

@media (max-width: 767px) {
  body[data-page="pg"] .ndppc-pgx-banner-frame,
  body[data-page="pg"] .ndppc-pgx-banner-frame img {
    min-height: 88px;
    max-height: 88px;
  }

  body[data-page="pg"] .ndppc-pgx-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: max(1rem, calc((100vw - 1320px) / 2 + 0.75rem));
    padding-right: max(1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  }

  body[data-page="pg"] .ndppc-pgx-banner-copy h1 {
    font-size: 1.65rem;
  }
}

/* Final PG Rebuild */
body[data-page="pg"] {
  --ndppc-pg3-surface: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(246, 241, 231, 0.96));
  --ndppc-pg3-panel: rgba(255, 255, 255, 0.8);
  --ndppc-pg3-border: rgba(139, 100, 20, 0.14);
  --ndppc-pg3-ink: var(--ndppc-primary-dark);
  --ndppc-pg3-copy: #52636f;
  --ndppc-pg3-green: linear-gradient(135deg, rgba(224, 240, 230, 0.98), rgba(250, 247, 238, 0.98));
  --ndppc-pg3-gold: linear-gradient(135deg, rgba(247, 238, 218, 0.98), rgba(255, 255, 255, 0.98));
  --ndppc-pg3-slate: linear-gradient(135deg, rgba(227, 236, 242, 0.98), rgba(255, 255, 255, 0.98));
}

body[data-page="pg"] .ndppc-pg3-overview-band {
  padding-top: 18px;
  padding-bottom: 26px;
}

body[data-page="pg"] .ndppc-pg3-overview-shell {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1rem;
  align-items: start;
}

body[data-page="pg"] .ndppc-pg3-overview-copy,
body[data-page="pg"] .ndppc-pg3-summary-panel,
body[data-page="pg"] .ndppc-pg3-pathway-card,
body[data-page="pg"] .ndppc-pg3-doctoral-card {
  border-radius: 30px;
  border: 1px solid var(--ndppc-pg3-border);
  background: var(--ndppc-pg3-surface);
  box-shadow: 0 18px 40px rgba(82, 60, 13, 0.07);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

body[data-page="pg"] .ndppc-pg3-overview-copy {
  padding: 1.45rem 1.5rem 1.5rem;
  display: grid;
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg3-overview-copy h2 {
  margin: 0;
  color: var(--ndppc-pg3-ink);
  font-size: clamp(1.9rem, 2.45vw, 2.7rem);
  line-height: 1.08;
}

body[data-page="pg"] .ndppc-pg3-overview-copy > p {
  margin: 0;
  color: var(--ndppc-pg3-copy);
  line-height: 1.8;
  text-align: justify;
}

body[data-page="pg"] .ndppc-pg3-mode-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.9rem;
}

body[data-page="pg"] .ndppc-pg3-mode-card {
  padding: 1rem 1rem 1.05rem;
  border-radius: 24px;
  border: 1px solid rgba(139, 100, 20, 0.1);
  display: grid;
  gap: 0.45rem;
}

body[data-page="pg"] .ndppc-pg3-mode-card--training {
  background: var(--ndppc-pg3-green);
}

body[data-page="pg"] .ndppc-pg3-mode-card--postdoc {
  background: var(--ndppc-pg3-gold);
}

body[data-page="pg"] .ndppc-pg3-mode-card--graduated {
  background: var(--ndppc-pg3-slate);
}

body[data-page="pg"] .ndppc-pg3-mode-card--current {
  background: linear-gradient(135deg, rgba(232, 241, 234, 0.98), rgba(233, 239, 245, 0.98));
}

body[data-page="pg"] .ndppc-pg3-mode-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

body[data-page="pg"] .ndppc-pg3-mode-count {
  color: #8b6414;
  font-size: 1.45rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="pg"] .ndppc-pg3-mode-top i {
  color: #215b3f;
  font-size: 1.15rem;
}

body[data-page="pg"] .ndppc-pg3-mode-card strong {
  color: var(--ndppc-pg3-ink);
  font-size: 1.02rem;
  line-height: 1.22;
}

body[data-page="pg"] .ndppc-pg3-mode-card span {
  color: var(--ndppc-pg3-copy);
  line-height: 1.6;
}

body[data-page="pg"] .ndppc-pg3-summary-panel {
  padding: 1.35rem 1.35rem 1.4rem;
  display: grid;
  align-content: start;
  gap: 0.95rem;
}

body[data-page="pg"] .ndppc-pg3-summary-panel h3 {
  margin: 0;
  color: var(--ndppc-pg3-ink);
  font-size: clamp(1.3rem, 1.85vw, 1.8rem);
  line-height: 1.15;
}

body[data-page="pg"] .ndppc-pg3-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

body[data-page="pg"] .ndppc-pg3-summary-card {
  min-height: 120px;
  padding: 1rem 0.95rem;
  border-radius: 22px;
  border: 1px solid rgba(139, 100, 20, 0.1);
  background: rgba(255, 255, 255, 0.78);
  display: grid;
  align-content: center;
  gap: 0.35rem;
}

body[data-page="pg"] .ndppc-pg3-summary-card strong {
  color: var(--ndppc-pg3-ink);
  font-size: clamp(1.5rem, 2vw, 2rem);
  line-height: 1;
}

body[data-page="pg"] .ndppc-pg3-summary-card span {
  color: var(--ndppc-pg3-copy);
  line-height: 1.5;
}

body[data-page="pg"] .ndppc-pg3-pathways-band,
body[data-page="pg"] .ndppc-pg3-doctoral-band {
  padding-top: 10px;
  padding-bottom: 30px;
}

body[data-page="pg"] .ndppc-pg3-section-head {
  display: grid;
  gap: 0.7rem;
  margin-bottom: 1rem;
}

body[data-page="pg"] .ndppc-pg3-section-head h2 {
  margin: 0;
  color: var(--ndppc-pg3-ink);
  font-size: clamp(1.7rem, 2.25vw, 2.35rem);
  line-height: 1.1;
}

body[data-page="pg"] .ndppc-pg3-section-head p {
  margin: 0;
  max-width: 78ch;
  color: var(--ndppc-pg3-copy);
  line-height: 1.8;
  text-align: justify;
}

body[data-page="pg"] .ndppc-pg3-pathway-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg3-pathway-card {
  padding: 1.15rem 1.2rem 1.2rem;
  display: grid;
  gap: 0.9rem;
}

body[data-page="pg"] .ndppc-pg3-pathway-card:hover,
body[data-page="pg"] .ndppc-pg3-summary-panel:hover,
body[data-page="pg"] .ndppc-pg3-doctoral-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 46px rgba(33, 91, 63, 0.12);
  border-color: rgba(33, 91, 63, 0.2);
}

body[data-page="pg"] .ndppc-pg3-pathway-top,
body[data-page="pg"] .ndppc-pg3-doctoral-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
}

body[data-page="pg"] .ndppc-pg3-pathway-top strong,
body[data-page="pg"] .ndppc-pg3-doctoral-top strong {
  color: #6c7683;
  font-size: 0.9rem;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg3-pathway-core {
  display: grid;
  grid-template-columns: 62px minmax(0, 1fr);
  gap: 0.9rem;
  align-items: start;
}

body[data-page="pg"] .ndppc-pg3-pathway-icon {
  width: 62px;
  height: 62px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(226, 241, 233, 0.98), rgba(244, 239, 228, 0.98));
  color: #215b3f;
  font-size: 1.25rem;
}

body[data-page="pg"] .ndppc-pg3-pathway-copy h3,
body[data-page="pg"] .ndppc-pg3-doctoral-head h3 {
  margin: 0 0 0.35rem;
  color: var(--ndppc-pg3-ink);
  font-size: 1.3rem;
  line-height: 1.2;
}

body[data-page="pg"] .ndppc-pg3-role {
  margin: 0;
  color: #8b6414;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg3-meta-list,
body[data-page="pg"] .ndppc-pg3-objectives {
  margin: 0;
  padding-left: 1.05rem;
  color: #475865;
}

body[data-page="pg"] .ndppc-pg3-meta-list li,
body[data-page="pg"] .ndppc-pg3-objectives li {
  margin-bottom: 0.5rem;
  line-height: 1.7;
}

body[data-page="pg"] .ndppc-pg3-focus,
body[data-page="pg"] .ndppc-pg3-topic {
  margin: 0;
  color: #4a5b67;
  line-height: 1.8;
  text-align: justify;
}

body[data-page="pg"] .ndppc-pg3-doctoral-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg3-doctoral-card {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr);
  overflow: hidden;
  align-items: stretch;
}

body[data-page="pg"] .ndppc-pg3-doctoral-photo {
  margin: 0;
}

body[data-page="pg"] .ndppc-pg3-doctoral-photo img {
  width: 100%;
  height: 100%;
  min-height: 220px;
  object-fit: cover;
  object-position: center top;
  display: block;
}

body[data-page="pg"] .ndppc-pg3-doctoral-copy {
  padding: 1rem 1.05rem 1.05rem;
  display: grid;
  align-content: start;
  gap: 0.75rem;
}

body[data-page="pg"] .ndppc-pg3-doctoral-card--graduated .ndppc-pg3-doctoral-photo {
  background: var(--ndppc-pg3-slate);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.55rem;
}

body[data-page="pg"] .ndppc-pg3-doctoral-card--current .ndppc-pg3-doctoral-photo {
  background: var(--ndppc-pg3-green);
}

body[data-page="pg"] .ndppc-pg3-doctoral-card--graduated .ndppc-pg3-doctoral-photo img {
  height: auto;
  min-height: 0;
  aspect-ratio: 1 / 1;
  max-height: none;
  object-fit: contain;
  object-position: center center;
  border-radius: 20px;
}

body[data-page="pg"] .ndppc-pg3-doctoral-card--graduated {
  grid-template-columns: 205px minmax(0, 1fr);
}

body[data-page="pg"] .ndppc-pg3-doctoral-head h3 {
  font-size: 1.15rem;
}

body[data-page="pg"] .ndppc-pg3-doctoral-copy .rounded-pill {
  font-size: 0.74rem;
}

body[data-page="pg"] .ndppc-pg3-meta-list,
body[data-page="pg"] .ndppc-pg3-objectives {
  font-size: 0.94rem;
}

body[data-page="pg"] .ndppc-pg3-topic,
body[data-page="pg"] .ndppc-pg3-focus {
  font-size: 0.95rem;
}

@media (max-width: 1199px) {
  body[data-page="pg"] .ndppc-pg3-pathway-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pg3-mode-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="pg"] .ndppc-pg3-doctoral-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pg3-doctoral-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991px) {
  body[data-page="pg"] .ndppc-pg3-mode-grid,
  body[data-page="pg"] .ndppc-pg3-summary-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pg3-overview-copy h2 {
    font-size: clamp(1.7rem, 5.6vw, 2.2rem);
  }
}

@media (max-width: 767px) {
  body[data-page="pg"] .ndppc-pg3-overview-copy,
  body[data-page="pg"] .ndppc-pg3-summary-panel,
  body[data-page="pg"] .ndppc-pg3-pathway-card,
  body[data-page="pg"] .ndppc-pg3-doctoral-copy {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body[data-page="pg"] .ndppc-pg3-doctoral-photo img {
    min-height: 210px;
  }

  body[data-page="pg"] .ndppc-pg3-doctoral-card--graduated .ndppc-pg3-doctoral-photo img {
    max-width: 220px;
  }

  body[data-page="pg"] .ndppc-pg3-pathway-top,
  body[data-page="pg"] .ndppc-pg3-doctoral-top {
    align-items: start;
    flex-direction: column;
  }
}

/* PG Interactive Refresh */
body[data-page="pg"] .ndppc-pg4-overview-band {
  padding-top: 18px;
  padding-bottom: 24px;
}

body[data-page="pg"] .ndppc-pg4-overview-shell,
body[data-page="pg"] .ndppc-pg4-overview-copy {
  display: grid;
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg4-mode-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.95rem;
}

body[data-page="pg"] .ndppc-pg4-mode-card,
body[data-page="pg"] .ndppc-pg4-pathway-card,
body[data-page="pg"] .ndppc-pg4-completed-card,
body[data-page="pg"] .ndppc-pg4-current-card {
  border-radius: 28px;
  border: 1px solid rgba(139, 100, 20, 0.14);
  box-shadow: 0 16px 36px rgba(82, 60, 13, 0.08);
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

body[data-page="pg"] .ndppc-pg4-mode-card {
  display: grid;
  gap: 0.85rem;
  padding: 1.1rem 1.15rem;
  color: inherit;
  text-decoration: none;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 242, 232, 0.96));
}

body[data-page="pg"] .ndppc-pg4-mode-card:hover,
body[data-page="pg"] .ndppc-pg4-pathway-card:hover,
body[data-page="pg"] .ndppc-pg4-completed-card:hover,
body[data-page="pg"] .ndppc-pg4-current-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 42px rgba(33, 91, 63, 0.12);
  border-color: rgba(33, 91, 63, 0.2);
}

body[data-page="pg"] .ndppc-pg4-mode-card--training {
  background: linear-gradient(145deg, rgba(226, 241, 233, 0.98), rgba(250, 247, 238, 0.98));
}

body[data-page="pg"] .ndppc-pg4-mode-card--postdoc {
  background: linear-gradient(145deg, rgba(247, 238, 218, 0.98), rgba(255, 255, 255, 0.98));
}

body[data-page="pg"] .ndppc-pg4-mode-card--graduated {
  background: linear-gradient(145deg, rgba(227, 236, 242, 0.98), rgba(255, 255, 255, 0.98));
}

body[data-page="pg"] .ndppc-pg4-mode-card--current {
  background: linear-gradient(145deg, rgba(232, 241, 234, 0.98), rgba(233, 239, 245, 0.98));
}

body[data-page="pg"] .ndppc-pg4-mode-top,
body[data-page="pg"] .ndppc-pg4-record-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
}

body[data-page="pg"] .ndppc-pg4-mode-count {
  color: #8b6414;
  font-size: 1.7rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="pg"] .ndppc-pg4-mode-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.7);
  color: #215b3f;
  font-size: 1.1rem;
}

body[data-page="pg"] .ndppc-pg4-mode-body {
  display: grid;
  gap: 0.35rem;
}

body[data-page="pg"] .ndppc-pg4-mode-body strong {
  color: var(--ndppc-primary-dark);
  font-size: 1.04rem;
  line-height: 1.25;
}

body[data-page="pg"] .ndppc-pg4-mode-body span {
  color: #536672;
  line-height: 1.55;
}

body[data-page="pg"] .ndppc-pg4-mode-link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: #215b3f;
  font-size: 0.92rem;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg4-section-head {
  display: grid;
  gap: 0.7rem;
  margin-bottom: 1rem;
}

body[data-page="pg"] .ndppc-pg4-section-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.72rem, 2.25vw, 2.38rem);
  line-height: 1.1;
}

body[data-page="pg"] .ndppc-pg4-pathways-band,
body[data-page="pg"] .ndppc-pg4-completed-band,
body[data-page="pg"] .ndppc-pg4-current-band {
  padding-top: 8px;
  padding-bottom: 30px;
  scroll-margin-top: 110px;
}

body[data-page="pg"] .ndppc-pg4-pathway-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg4-pathway-card {
  display: grid;
  gap: 0.95rem;
  padding: 1.15rem 1.15rem 1.2rem;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 242, 232, 0.96));
}

body[data-page="pg"] .ndppc-pg4-pathway-card--training {
  background: linear-gradient(145deg, rgba(226, 241, 233, 0.98), rgba(255, 255, 255, 0.98));
}

body[data-page="pg"] .ndppc-pg4-pathway-card--postdoc {
  background: linear-gradient(145deg, rgba(247, 238, 218, 0.98), rgba(255, 255, 255, 0.98));
}

body[data-page="pg"] .ndppc-pg4-pathway-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
}

body[data-page="pg"] .ndppc-pg4-pathway-icon {
  width: 58px;
  height: 58px;
  border-radius: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.72);
  color: #215b3f;
  font-size: 1.2rem;
}

body[data-page="pg"] .ndppc-pg4-pathway-head {
  display: grid;
  gap: 0.25rem;
}

body[data-page="pg"] .ndppc-pg4-pathway-head h3,
body[data-page="pg"] .ndppc-pg4-record-head h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.22rem;
  line-height: 1.2;
}

body[data-page="pg"] .ndppc-pg4-pathway-head p,
body[data-page="pg"] .ndppc-pg4-record-role {
  margin: 0;
  color: #8b6414;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg4-pathway-meta,
body[data-page="pg"] .ndppc-pg4-record-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}

body[data-page="pg"] .ndppc-pg4-pathway-meta span,
body[data-page="pg"] .ndppc-pg4-record-meta span {
  padding: 0.45rem 0.7rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #51626e;
  line-height: 1.45;
}

body[data-page="pg"] .ndppc-pg4-completed-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg4-completed-card {
  display: grid;
  grid-template-columns: 205px minmax(0, 1fr);
  background: linear-gradient(145deg, rgba(227, 236, 242, 0.98), rgba(255, 255, 255, 0.98));
  overflow: hidden;
}

body[data-page="pg"] .ndppc-pg4-completed-photo,
body[data-page="pg"] .ndppc-pg4-current-photo {
  margin: 0;
  display: grid;
  place-items: center;
}

body[data-page="pg"] .ndppc-pg4-completed-photo {
  padding: 0.7rem;
  background: linear-gradient(180deg, rgba(227, 236, 242, 0.96), rgba(255, 255, 255, 0.96));
}

body[data-page="pg"] .ndppc-pg4-completed-photo img {
  width: 100%;
  max-width: 190px;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  object-position: center center;
  border-radius: 22px;
  display: block;
}

body[data-page="pg"] .ndppc-pg4-record-copy,
body[data-page="pg"] .ndppc-pg4-current-copy {
  display: grid;
  align-content: start;
  gap: 0.85rem;
  padding: 1rem 1.05rem 1.05rem;
}

body[data-page="pg"] .ndppc-pg4-record-top strong {
  color: #65717e;
  font-size: 0.9rem;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg4-record-head {
  display: grid;
  gap: 0.3rem;
}

body[data-page="pg"] .ndppc-pg4-current-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="pg"] .ndppc-pg4-current-card {
  display: grid;
  gap: 0;
  overflow: hidden;
  background: linear-gradient(145deg, rgba(232, 241, 234, 0.98), rgba(255, 255, 255, 0.98));
}

body[data-page="pg"] .ndppc-pg4-current-photo {
  padding: 0.85rem 0.85rem 0;
  background: linear-gradient(180deg, rgba(224, 240, 230, 0.98), rgba(255, 255, 255, 0.98));
  align-content: center;
  justify-items: center;
}

body[data-page="pg"] .ndppc-pg4-current-photo img {
  width: 100%;
  max-width: 180px;
  aspect-ratio: 1 / 1.08;
  object-fit: cover;
  object-position: center top;
  border-radius: 30px 30px 18px 18px;
  border: 4px solid rgba(255, 255, 255, 0.96);
  box-shadow:
    0 16px 30px rgba(32, 78, 55, 0.08),
    inset 0 0 0 1px rgba(20, 53, 38, 0.06);
  background: linear-gradient(180deg, rgba(227, 241, 233, 0.92), rgba(245, 239, 223, 0.92));
  display: block;
}

body[data-page="pg"] .ndppc-pg4-toggle {
  border-top: 1px solid rgba(139, 100, 20, 0.12);
  padding-top: 0.7rem;
}

body[data-page="pg"] .ndppc-pg4-toggle summary {
  list-style: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  color: #215b3f;
  font-weight: 700;
}

body[data-page="pg"] .ndppc-pg4-toggle summary::-webkit-details-marker {
  display: none;
}

body[data-page="pg"] .ndppc-pg4-toggle summary::after {
  content: "+";
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.8);
  color: #8b6414;
  font-size: 1.05rem;
  font-weight: 800;
  flex: 0 0 auto;
}

body[data-page="pg"] .ndppc-pg4-toggle[open] summary::after {
  content: "−";
}

body[data-page="pg"] .ndppc-pg4-toggle-body {
  padding-top: 0.8rem;
  color: #4a5b67;
}

body[data-page="pg"] .ndppc-pg4-toggle-body p,
body[data-page="pg"] .ndppc-pg4-topic {
  margin: 0;
  line-height: 1.75;
  text-align: justify;
}

body[data-page="pg"] .ndppc-pg4-objectives {
  margin: 0;
  padding-left: 1.05rem;
  color: #4a5b67;
}

body[data-page="pg"] .ndppc-pg4-objectives li {
  margin-bottom: 0.5rem;
  line-height: 1.7;
}

@media (max-width: 1199px) {
  body[data-page="pg"] .ndppc-pg4-mode-grid,
  body[data-page="pg"] .ndppc-pg4-current-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="pg"] .ndppc-pg4-pathway-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pg4-completed-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 991px) {
  body[data-page="pg"] .ndppc-pg4-mode-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="pg"] .ndppc-pg4-completed-card {
    grid-template-columns: 180px minmax(0, 1fr);
  }
}

@media (max-width: 767px) {
  body[data-page="pg"] .ndppc-pg4-overview-band,
  body[data-page="pg"] .ndppc-pg4-pathways-band,
  body[data-page="pg"] .ndppc-pg4-completed-band,
  body[data-page="pg"] .ndppc-pg4-current-band {
    padding-top: 10px;
    padding-bottom: 24px;
  }

  body[data-page="pg"] .ndppc-pg4-mode-grid,
  body[data-page="pg"] .ndppc-pg4-current-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pg4-mode-card,
  body[data-page="pg"] .ndppc-pg4-pathway-card,
  body[data-page="pg"] .ndppc-pg4-record-copy,
  body[data-page="pg"] .ndppc-pg4-current-copy {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body[data-page="pg"] .ndppc-pg4-completed-card {
    grid-template-columns: 1fr;
  }

  body[data-page="pg"] .ndppc-pg4-completed-photo {
    padding-bottom: 0;
  }

  body[data-page="pg"] .ndppc-pg4-record-top,
  body[data-page="pg"] .ndppc-pg4-pathway-top {
    align-items: start;
    flex-direction: column;
  }

  body[data-page="pg"] .ndppc-pg4-section-head h2 {
    font-size: 1.58rem;
  }
}

body[data-page="services"] .banner.ndppc-services-banner {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

body[data-page="services"] .banner.ndppc-services-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="services"] .banner.ndppc-services-banner .banner_inner {
  padding: 0 !important;
  min-height: 0 !important;
  overflow: visible;
  background: transparent !important;
  background-image: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

body[data-page="services"] .banner_content.ndppc-services-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="services"] .ndppc-services-banner-frame {
  position: relative;
  width: 100%;
  overflow: hidden;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
}

body[data-page="services"] .ndppc-services-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  object-fit: cover;
  object-position: center center;
  display: block;
}

body[data-page="services"] .ndppc-services-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="services"] .ndppc-services-banner-copy {
  display: grid;
  gap: 1rem;
  width: 100%;
  max-width: none;
  margin: 0;
  position: absolute;
  inset: 0;
  z-index: 1;
  align-content: center;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="services"] .ndppc-services-banner-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0;
  font-size: 0.95rem;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="services"] .ndppc-services-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="services"] .ndppc-services-banner-copy h1 {
  margin: 0;
  max-width: none;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.04;
  white-space: normal;
  text-shadow: none;
}

body[data-page="services"] .ndppc-services-dossier-band {
  padding-top: 30px;
  padding-bottom: 34px;
}

body[data-page="services"] .ndppc-services-dossier {
  display: grid;
  gap: 1.1rem;
}

body[data-page="services"] .ndppc-services-dossier-head,
body[data-page="services"] .ndppc-services-dossier-card {
  border: 1px solid rgba(15, 43, 30, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 242, 231, 0.98) 100%);
  box-shadow: 0 20px 40px rgba(107, 80, 26, 0.06);
}

body[data-page="services"] .ndppc-services-dossier-head {
  padding: 1.45rem 1.55rem;
  border-radius: 28px;
}

body[data-page="services"] .ndppc-services-dossier-head-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(260px, 0.88fr);
  gap: 1.1rem;
  align-items: start;
}

body[data-page="services"] .ndppc-services-dossier-head-copy {
  display: grid;
  align-content: start;
}

body[data-page="services"] .ndppc-services-dossier-head .rounded-pill {
  background: #f3ecda;
  color: #8b6414;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="services"] .ndppc-services-dossier-head h2 {
  margin: 0.85rem 0 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2vw, 2.08rem);
  line-height: 1.12;
}

body[data-page="services"] .ndppc-services-dossier-head p {
  margin: 0.95rem 0 0;
  color: rgba(15, 43, 30, 0.8);
  line-height: 1.78;
}

body[data-page="services"] .ndppc-services-dossier-docs {
  display: grid;
  gap: 0.85rem;
  justify-items: end;
  align-content: start;
  padding: 0.1rem 0 0;
}

body[data-page="services"] .ndppc-services-dossier-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.15fr) minmax(0, 0.9fr);
  gap: 1rem;
}

body[data-page="services"] .ndppc-services-dossier-card {
  border-radius: 26px;
  padding: 1.25rem 1.25rem 1.2rem;
  display: grid;
  gap: 0.9rem;
  align-content: start;
}

body[data-page="services"] .ndppc-services-dossier-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.18rem;
  line-height: 1.22;
}

body[data-page="services"] .ndppc-services-dossier-links {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.7rem;
}

body[data-page="services"] .ndppc-services-doc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0.85rem 1.2rem;
  border-radius: 999px;
  border: 1px solid rgba(15, 43, 30, 0.12);
  font-weight: 700;
  line-height: 1;
}

body[data-page="services"] .ndppc-services-doc-btn--solid {
  background: linear-gradient(135deg, rgba(27, 106, 75, 0.96) 0%, rgba(15, 43, 30, 0.96) 100%);
  border-color: transparent;
  color: #fff;
}

body[data-page="services"] .ndppc-services-doc-btn--ghost {
  background: rgba(255, 255, 255, 0.88);
  color: var(--ndppc-primary-dark);
}

body[data-page="services"] .ndppc-services-dossier-card--charges {
  background:
    radial-gradient(circle at top right, rgba(27, 106, 75, 0.1), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(241, 246, 243, 0.98) 100%);
}

body[data-page="services"] .ndppc-services-dossier-list {
  margin: 0;
  padding-left: 1.1rem;
}

body[data-page="services"] .ndppc-services-dossier-list li,
body[data-page="services"] .ndppc-services-rate-item span {
  color: rgba(15, 43, 30, 0.8);
  line-height: 1.72;
}

body[data-page="services"] .ndppc-services-dossier-list li + li {
  margin-top: 0.35rem;
}

body[data-page="services"] .ndppc-services-rate-list {
  display: grid;
  gap: 0.95rem;
}

body[data-page="services"] .ndppc-services-rate-item {
  display: grid;
  gap: 0.22rem;
}

body[data-page="services"] .ndppc-services-rate-item strong {
  color: var(--ndppc-primary-dark);
  font-size: 0.98rem;
}

body[data-page="services"] .ndppc-services-point-grid {
  justify-content: start;
}

body[data-page="services"] .ndppc-services-overview-band {
  padding-top: 32px;
  padding-bottom: 26px;
}

body[data-page="services"] .ndppc-services-overview {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
  gap: 1.35rem;
  align-items: stretch;
}

body[data-page="services"] .ndppc-services-overview-copy,
body[data-page="services"] .ndppc-services-doc-card,
body[data-page="services"] .ndppc-services-approval-copy,
body[data-page="services"] .ndppc-services-approval-card,
body[data-page="services"] .ndppc-services-route-card,
body[data-page="services"] .ndppc-services-module-card {
  border: 1px solid rgba(15, 43, 30, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 242, 231, 0.98) 100%);
  box-shadow: 0 20px 40px rgba(107, 80, 26, 0.06);
}

body[data-page="services"] .ndppc-services-overview-copy {
  padding: 1.45rem 1.55rem;
  border-radius: 28px;
}

body[data-page="services"] .ndppc-services-overview-copy .rounded-pill,
body[data-page="services"] .ndppc-services-section-head .rounded-pill,
body[data-page="services"] .ndppc-services-doc-card .rounded-pill,
body[data-page="services"] .ndppc-services-approval-copy .rounded-pill,
body[data-page="services"] .ndppc-services-approval-card .rounded-pill,
body[data-page="services"] .ndppc-services-module-copy .rounded-pill {
  background: #f3ecda;
  color: #8b6414;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="services"] .ndppc-services-overview-copy h2,
body[data-page="services"] .ndppc-services-approval-copy h2,
body[data-page="services"] .ndppc-services-section-head h2 {
  margin: 0.85rem 0 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2vw, 2.08rem);
  line-height: 1.12;
}

body[data-page="services"] .ndppc-services-overview-copy p {
  margin: 0.95rem 0 0;
  color: rgba(15, 43, 30, 0.8);
  line-height: 1.78;
}

body[data-page="services"] .ndppc-services-approval-band,
body[data-page="services"] .ndppc-services-route-band,
body[data-page="services"] .ndppc-services-module-band,
body[data-page="services"] .ndppc-services-follow-band {
  padding-top: 26px;
  padding-bottom: 30px;
}

body[data-page="services"] .ndppc-services-approval {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
  gap: 1.2rem;
  align-items: stretch;
}

body[data-page="services"] .ndppc-services-approval-copy {
  padding: 1.45rem 1.55rem;
  border-radius: 28px;
  display: grid;
  gap: 0.85rem;
  align-content: start;
}

body[data-page="services"] .ndppc-services-approval-copy p,
body[data-page="services"] .ndppc-services-approval-card p,
body[data-page="services"] .ndppc-services-approval-list li {
  color: rgba(15, 43, 30, 0.8);
  line-height: 1.78;
}

body[data-page="services"] .ndppc-services-approval-copy p {
  margin: 0;
}

body[data-page="services"] .ndppc-services-approval-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="services"] .ndppc-services-approval-card {
  border-radius: 26px;
  padding: 1.25rem 1.25rem 1.2rem;
  display: grid;
  gap: 0.75rem;
  align-content: start;
}

body[data-page="services"] .ndppc-services-approval-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.18rem;
  line-height: 1.22;
}

body[data-page="services"] .ndppc-services-approval-list {
  margin: 0;
  padding-left: 1.1rem;
}

body[data-page="services"] .ndppc-services-approval-list li + li {
  margin-top: 0.4rem;
}

body[data-page="services"] .ndppc-services-doc-stack {
  display: grid;
  gap: 1rem;
}

body[data-page="services"] .ndppc-services-doc-card {
  border-radius: 26px;
  padding: 1.3rem 1.35rem;
}

body[data-page="services"] .ndppc-services-doc-card h3,
body[data-page="services"] .ndppc-services-module-copy h3 {
  margin: 0.9rem 0 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.28rem;
  line-height: 1.18;
}

body[data-page="services"] .ndppc-services-doc-card p,
body[data-page="services"] .ndppc-services-route-card p,
body[data-page="services"] .ndppc-services-module-copy p {
  margin: 0.8rem 0 0;
  color: rgba(15, 43, 30, 0.78);
  line-height: 1.7;
}

body[data-page="services"] .ndppc-services-section-head {
  display: grid;
  gap: 0.2rem;
  margin-bottom: 1.2rem;
}

body[data-page="services"] .ndppc-services-route-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="services"] .ndppc-services-route-card {
  min-height: 240px;
  border-radius: 26px;
  padding: 1.25rem 1.25rem 1.2rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

body[data-page="services"] .ndppc-services-route-top {
  display: grid;
  gap: 0.8rem;
}

body[data-page="services"] .ndppc-services-route-top strong {
  width: fit-content;
  padding: 0.42rem 0.72rem;
  border-radius: 999px;
  background: rgba(15, 43, 30, 0.08);
  color: var(--ndppc-primary-dark);
  font-size: 0.95rem;
  line-height: 1;
}

body[data-page="services"] .ndppc-services-route-top span {
  color: var(--ndppc-primary-dark);
  font-size: 1.12rem;
  font-weight: 700;
  line-height: 1.28;
}

body[data-page="services"] .ndppc-services-route-card .ndppc-inline-link,
body[data-page="services"] .ndppc-services-doc-card .ndppc-inline-link,
body[data-page="services"] .ndppc-services-module-card .ndppc-inline-link {
  margin-top: auto;
}

body[data-page="services"] .ndppc-services-module-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1.15rem;
}

body[data-page="services"] .ndppc-services-module-card {
  display: grid;
  grid-template-columns: minmax(210px, 0.86fr) minmax(0, 1fr);
  overflow: hidden;
  border-radius: 30px;
}

body[data-page="services"] .ndppc-services-module-media {
  min-height: 100%;
}

body[data-page="services"] .ndppc-services-module-media img {
  width: 100%;
  height: 100%;
  min-height: 280px;
  object-fit: cover;
  object-position: center;
  display: block;
}

body[data-page="services"] .ndppc-services-module-copy {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  padding: 1.35rem 1.35rem 1.25rem;
}

body[data-page="services"] .ndppc-services-point-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

body[data-page="services"] .ndppc-services-point-grid span {
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 0.8rem;
  border-radius: 999px;
  border: 1px solid rgba(15, 43, 30, 0.1);
  background: rgba(255, 255, 255, 0.82);
  color: var(--ndppc-primary-dark);
  font-weight: 600;
  font-size: 0.92rem;
  line-height: 1.25;
}

body[data-page="services"] .ndppc-services-follow-band .ndppc-link-grid .application-card {
  height: 100%;
  border-radius: 24px;
}

@media (max-width: 1199px) {
  body[data-page="services"] .ndppc-services-route-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="services"] .ndppc-services-module-card {
    grid-template-columns: minmax(180px, 0.75fr) minmax(0, 1fr);
  }
}

@media (max-width: 991px) {
  body[data-page="services"] .ndppc-services-banner-frame,
  body[data-page="services"] .ndppc-services-banner-frame img {
    min-height: 102px;
  }

  body[data-page="services"] .ndppc-services-banner-copy {
    padding-top: 1.45rem;
    padding-bottom: 1.45rem;
    padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
    padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  }

  body[data-page="services"] .ndppc-services-overview {
    grid-template-columns: 1fr;
  }

  body[data-page="services"] .ndppc-services-approval {
    grid-template-columns: 1fr;
  }

  body[data-page="services"] .ndppc-services-approval-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body[data-page="services"] .ndppc-services-dossier-grid {
    grid-template-columns: 1fr 1fr;
  }

  body[data-page="services"] .ndppc-services-dossier-head-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="services"] .ndppc-services-dossier-docs {
    justify-items: start;
  }

  body[data-page="services"] .ndppc-services-dossier-links {
    justify-content: flex-start;
  }

  body[data-page="services"] .ndppc-services-module-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="services"] .ndppc-services-banner-frame,
  body[data-page="services"] .ndppc-services-banner-frame img {
    min-height: 88px;
  }

  body[data-page="services"] .ndppc-services-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="services"] .ndppc-services-banner-copy h1 {
    max-width: none;
    font-size: 1.65rem;
  }

  body[data-page="services"] .ndppc-services-overview-band,
  body[data-page="services"] .ndppc-services-dossier-band,
  body[data-page="services"] .ndppc-services-approval-band,
  body[data-page="services"] .ndppc-services-route-band,
  body[data-page="services"] .ndppc-services-module-band,
  body[data-page="services"] .ndppc-services-follow-band {
    padding-top: 22px;
    padding-bottom: 24px;
  }

  body[data-page="services"] .ndppc-services-overview-copy,
  body[data-page="services"] .ndppc-services-dossier-head,
  body[data-page="services"] .ndppc-services-dossier-card,
  body[data-page="services"] .ndppc-services-approval-copy,
  body[data-page="services"] .ndppc-services-approval-card,
  body[data-page="services"] .ndppc-services-doc-card,
  body[data-page="services"] .ndppc-services-route-card {
    padding: 1.1rem 1rem;
    border-radius: 22px;
  }

body[data-page="services"] .ndppc-services-dossier-grid,
body[data-page="services"] .ndppc-services-approval-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="services"] .ndppc-services-dossier-links {
    flex-direction: column;
    align-items: stretch;
  }

  body[data-page="services"] .ndppc-services-doc-btn {
    width: 100%;
  }

  body[data-page="services"] .ndppc-services-route-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="services"] .ndppc-services-route-card {
    min-height: 0;
  }

  body[data-page="services"] .ndppc-services-module-card {
    grid-template-columns: 1fr;
  }

  body[data-page="services"] .ndppc-services-module-media img {
    min-height: 200px;
    max-height: 200px;
  }

  body[data-page="services"] .ndppc-services-module-copy {
    padding: 1.05rem 1rem 1rem;
  }
}

/* Final Contact Page */
body[data-page="contact"] .banner.ndppc-contact-banner {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

body[data-page="contact"] .banner.ndppc-contact-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="contact"] .banner.ndppc-contact-banner .banner_inner {
  padding: 0;
  min-height: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="contact"] .banner_content.ndppc-contact-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="contact"] .ndppc-contact-banner-frame {
  position: relative;
  width: 100%;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
  overflow: hidden;
}

body[data-page="contact"] .ndppc-contact-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="contact"] .ndppc-contact-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="contact"] .ndppc-contact-banner-copy {
  display: grid;
  gap: 1rem;
  width: 100%;
  max-width: none;
  margin: 0;
  position: absolute;
  inset: 0;
  align-content: center;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="contact"] .ndppc-contact-banner-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="contact"] .ndppc-contact-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="contact"] .ndppc-contact-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.08;
}

body[data-page="contact"] .ndppc-contact-overview-band,
body[data-page="contact"] .ndppc-contact-main-band,
body[data-page="contact"] .ndppc-contact-map-band {
  padding-top: 26px;
  padding-bottom: 30px;
}

body[data-page="contact"] .ndppc-contact-overview {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap: 1.2rem;
  align-items: stretch;
}

body[data-page="contact"] .ndppc-contact-overview-copy,
body[data-page="contact"] .ndppc-contact-quick-card,
body[data-page="contact"] .ndppc-contact-record,
body[data-page="contact"] .ndppc-contact-form-shell,
body[data-page="contact"] .ndppc-contact-map-copy,
body[data-page="contact"] .ndppc-contact-map-frame {
  border: 1px solid rgba(15, 43, 30, 0.08);
  box-shadow: 0 20px 40px rgba(107, 80, 26, 0.06);
}

body[data-page="contact"] .ndppc-contact-overview-copy,
body[data-page="contact"] .ndppc-contact-record,
body[data-page="contact"] .ndppc-contact-form-shell {
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 242, 231, 0.98) 100%);
}

body[data-page="contact"] .ndppc-contact-overview-copy {
  display: grid;
  gap: 0.9rem;
  align-content: start;
  padding: 1.45rem 1.55rem;
}

body[data-page="contact"] .ndppc-contact-overview-copy .rounded-pill,
body[data-page="contact"] .ndppc-contact-record .rounded-pill,
body[data-page="contact"] .ndppc-contact-form-head .rounded-pill,
body[data-page="contact"] .ndppc-contact-map-copy .rounded-pill {
  justify-self: start;
  background: #f3ecda;
  color: #8b6414;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="tandw"] .banner.ndppc-tandw-banner {
  position: relative;
  padding-top: 0;
}

body[data-page="tandw"] .banner.ndppc-tandw-banner .container {
  width: 100%;
  max-width: none;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="tandw"] .banner.ndppc-tandw-banner .banner_inner {
  width: 100%;
  min-height: 0;
  padding: 0;
  overflow: visible;
  background: transparent;
  box-shadow: none;
}

body[data-page="tandw"] .banner_content.ndppc-tandw-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
  padding: 0;
}

body[data-page="tandw"] .ndppc-tandw-banner-frame {
  position: relative;
  margin: 0;
  width: 100%;
  overflow: hidden;
}

body[data-page="tandw"] .ndppc-tandw-banner-frame,
body[data-page="tandw"] .ndppc-tandw-banner-frame img {
  min-height: 120px;
  max-height: 170px;
}

body[data-page="tandw"] .ndppc-tandw-banner-frame img {
  width: 100%;
  display: block;
  object-fit: cover;
  object-position: center center;
}

body[data-page="tandw"] .ndppc-tandw-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="tandw"] .ndppc-tandw-banner-copy {
  position: absolute;
  inset: 0;
  z-index: 2;
  width: 100%;
  max-width: none;
  margin: 0;
  display: grid;
  align-content: center;
  justify-items: start;
  gap: 1rem;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
}

body[data-page="tandw"] .ndppc-tandw-banner-breadcrumbs {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-bottom: 0;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="tandw"] .ndppc-tandw-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="tandw"] .ndppc-tandw-banner-copy h1 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.08;
}

body[data-page="tandw"] .ndppc-tandw-overview-band,
body[data-page="tandw"] .ndppc-tandw-groups-band,
body[data-page="tandw"] .ndppc-tandw-programmes-band,
body[data-page="tandw"] .ndppc-tandw-workshop-band {
  padding-top: 28px;
  padding-bottom: 30px;
}

body[data-page="tandw"] .ndppc-tandw-groups-band {
  padding-top: 14px;
}

body[data-page="tandw"] .ndppc-tandw-overview {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(280px, 0.92fr);
  gap: 1.2rem;
  align-items: stretch;
}

body[data-page="tandw"] .ndppc-tandw-overview-copy,
body[data-page="tandw"] .ndppc-tandw-stat-card,
body[data-page="tandw"] .ndppc-tandw-programme-card,
body[data-page="tandw"] .ndppc-tandw-access-card,
body[data-page="tandw"] .ndppc-tandw-support-card {
  border: 1px solid rgba(18, 44, 34, 0.08);
  box-shadow: 0 18px 40px rgba(18, 44, 34, 0.06);
}

body[data-page="tandw"] .ndppc-tandw-overview-copy {
  display: grid;
  gap: 0.95rem;
  padding: 1.45rem 1.5rem;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, rgba(140, 109, 49, 0.14), transparent 35%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 244, 237, 0.98) 100%);
}

body[data-page="tandw"] .ndppc-tandw-overview-copy .rounded-pill,
body[data-page="tandw"] .ndppc-tandw-section-head .rounded-pill,
body[data-page="tandw"] .ndppc-tandw-programme-meta .rounded-pill,
body[data-page="tandw"] .ndppc-tandw-access-card .rounded-pill {
  background: #f3ecda;
  color: #8b6414;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="tandw"] .ndppc-tandw-overview-copy h2,
body[data-page="tandw"] .ndppc-tandw-section-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
  line-height: 1.08;
}

body[data-page="tandw"] .ndppc-tandw-overview-copy p,
body[data-page="tandw"] .ndppc-tandw-programme-card .ndppc-card-copy,
body[data-page="tandw"] .ndppc-tandw-access-card .ndppc-card-copy,
body[data-page="tandw"] .ndppc-tandw-support-card .ndppc-card-copy {
  margin: 0;
  color: rgba(15, 43, 30, 0.8);
  line-height: 1.74;
}

body[data-page="tandw"] .ndppc-tandw-overview-stats {
  display: grid;
  gap: 0.95rem;
}

body[data-page="tandw"] .ndppc-tandw-stat-card {
  display: grid;
  align-content: start;
  gap: 0.35rem;
  padding: 1.15rem 1.1rem 1rem;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(236, 227, 207, 0.62) 100%);
}

body[data-page="tandw"] .ndppc-tandw-stat-card strong {
  display: block;
  font-size: 2rem;
  line-height: 1;
  color: var(--ndppc-primary-dark);
}

body[data-page="tandw"] .ndppc-tandw-stat-card span {
  color: rgba(15, 43, 30, 0.76);
  font-weight: 600;
}

body[data-page="tandw"] .ndppc-tandw-section-head {
  display: grid;
  gap: 0.7rem;
  margin-bottom: 1.1rem;
}

body[data-page="tandw"] .ndppc-tandw-tab-row {
  margin-bottom: 1.15rem;
}

body[data-page="tandw"] .ndppc-tandw-tab-row button {
  min-width: 190px;
}

body[data-page="tandw"] .ndppc-tandw-group-panel[hidden] {
  display: none !important;
}

body[data-page="tandw"] .ndppc-tandw-programme-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="tandw"] .ndppc-tandw-programme-card {
  display: grid;
  gap: 0.95rem;
  padding: 1.25rem 1.25rem 1.15rem;
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 244, 237, 0.98) 100%);
}

body[data-page="tandw"] .ndppc-tandw-card--emerald {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(229, 239, 233, 0.98) 100%);
}

body[data-page="tandw"] .ndppc-tandw-card--amber {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 239, 219, 0.98) 100%);
}

body[data-page="tandw"] .ndppc-tandw-programme-top {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.85rem;
  align-items: start;
}

body[data-page="tandw"] .ndppc-tandw-programme-icon {
  width: 52px;
  height: 52px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: rgba(18, 44, 34, 0.08);
  color: var(--ndppc-primary);
  font-size: 1.45rem;
}

body[data-page="tandw"] .ndppc-tandw-programme-meta {
  display: grid;
  gap: 0.35rem;
  align-content: start;
}

body[data-page="tandw"] .ndppc-tandw-programme-meta small {
  color: rgba(15, 43, 30, 0.62);
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

body[data-page="tandw"] .ndppc-tandw-programme-card h3,
body[data-page="tandw"] .ndppc-tandw-workshop-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  line-height: 1.16;
}

body[data-page="tandw"] .ndppc-tandw-workshop-grid {
  display: grid;
  gap: 1rem;
}

body[data-page="tandw"] .ndppc-tandw-workshop-card {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  gap: 1rem;
  align-items: stretch;
  padding: 1.2rem;
  border-radius: 28px;
  border: 1px solid rgba(18, 44, 34, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 244, 237, 0.98) 100%);
  box-shadow: 0 18px 40px rgba(18, 44, 34, 0.06);
}

body[data-page="tandw"] .ndppc-tandw-workshop-year {
  display: grid;
  place-items: center;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(29, 75, 57, 0.92) 0%, rgba(18, 44, 34, 0.96) 100%);
  color: #fff;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.04em;
}

body[data-page="tandw"] .ndppc-tandw-workshop-copy {
  display: grid;
  gap: 0.7rem;
  align-content: start;
}

body[data-page="tandw"] .ndppc-tandw-workshop-meta {
  display: grid;
  gap: 0.45rem;
}

body[data-page="tandw"] .ndppc-tandw-workshop-meta span {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.55rem;
  color: rgba(15, 43, 30, 0.78);
  line-height: 1.6;
}

body[data-page="tandw"] .ndppc-tandw-workshop-meta i {
  color: var(--ndppc-accent);
  margin-top: 0.18rem;
}

@media (max-width: 991px) {
  body[data-page="tandw"] .ndppc-tandw-banner-frame,
  body[data-page="tandw"] .ndppc-tandw-banner-frame img {
    min-height: 102px;
  }

  body[data-page="tandw"] .ndppc-tandw-programme-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="tandw"] .ndppc-tandw-banner-frame,
  body[data-page="tandw"] .ndppc-tandw-banner-frame img {
    min-height: 88px;
  }

  body[data-page="tandw"] .ndppc-tandw-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="tandw"] .ndppc-tandw-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="tandw"] .ndppc-tandw-overview-band,
  body[data-page="tandw"] .ndppc-tandw-groups-band,
  body[data-page="tandw"] .ndppc-tandw-programmes-band,
  body[data-page="tandw"] .ndppc-tandw-workshop-band {
    padding-top: 22px;
    padding-bottom: 24px;
  }

  body[data-page="tandw"] .ndppc-tandw-overview-copy,
  body[data-page="tandw"] .ndppc-tandw-programme-card,
  body[data-page="tandw"] .ndppc-tandw-workshop-card,
  body[data-page="tandw"] .ndppc-tandw-stat-card {
    padding: 1.1rem 1rem;
    border-radius: 22px;
  }

  body[data-page="tandw"] .ndppc-tandw-workshop-card {
    grid-template-columns: 1fr;
  }

  body[data-page="tandw"] .ndppc-tandw-workshop-year {
    min-height: 76px;
  }
}

body[data-page="tandw"] .ndppc-tandw-overview {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 1.15rem;
  align-items: stretch;
}

body[data-page="tandw"] .ndppc-tandw-overview-copy,
body[data-page="tandw"] .ndppc-tandw-stat-card,
body[data-page="tandw"] .ndppc-tandw-panel-shell,
body[data-page="tandw"] .ndppc-tandw-feature-card,
body[data-page="tandw"] .ndppc-tandw-archive-row {
  border: 1px solid rgba(18, 44, 34, 0.08);
  box-shadow: 0 18px 40px rgba(18, 44, 34, 0.06);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(247, 244, 237, 0.99) 100%);
}

body[data-page="tandw"] .ndppc-tandw-overview-copy {
  display: grid;
  gap: 0.95rem;
  padding: 1.5rem 1.6rem;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, rgba(140, 109, 49, 0.14), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(247, 244, 237, 0.99) 100%);
}

body[data-page="tandw"] .ndppc-tandw-overview-stats {
  display: grid;
  gap: 0.9rem;
}

body[data-page="tandw"] .ndppc-tandw-stat-card {
  display: grid;
  gap: 0.3rem;
  padding: 1.1rem 1.1rem 1rem;
  border-radius: 24px;
}

body[data-page="tandw"] .ndppc-tandw-stat-card strong {
  display: block;
  color: var(--ndppc-primary-dark);
  font-size: 1.9rem;
  line-height: 1;
}

body[data-page="tandw"] .ndppc-tandw-stat-card span {
  color: var(--ndppc-primary-dark);
  font-weight: 700;
}

body[data-page="tandw"] .ndppc-tandw-stat-card small {
  color: rgba(15, 43, 30, 0.72);
  line-height: 1.55;
}

body[data-page="tandw"] .ndppc-tandw-panel-shell {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  padding: 1.15rem;
  background:
    radial-gradient(circle at top right, rgba(27, 106, 75, 0.08), transparent 28%),
    radial-gradient(circle at bottom left, rgba(140, 109, 49, 0.08), transparent 32%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(247, 244, 237, 0.99) 100%);
}

body[data-page="tandw"] .ndppc-tandw-tab-row {
  display: inline-grid;
  grid-auto-flow: column;
  gap: 0.85rem;
  margin-bottom: 0.9rem;
}

body[data-page="tandw"] .ndppc-tandw-tab-row button {
  min-width: 220px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  padding: 0.95rem 1.2rem;
  border-radius: 999px;
  border: 1px solid rgba(18, 44, 34, 0.12);
  background: rgba(255, 255, 255, 0.92);
  color: var(--ndppc-primary-dark);
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.55);
}

body[data-page="tandw"] .ndppc-tandw-tab-row button span {
  display: inline-flex;
  min-width: 32px;
  height: 32px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(18, 44, 34, 0.08);
  color: var(--ndppc-primary);
  font-size: 0.9rem;
}

body[data-page="tandw"] .ndppc-tandw-tab-row button.active {
  background: linear-gradient(135deg, rgba(27, 106, 75, 0.96) 0%, rgba(15, 43, 30, 0.96) 100%);
  color: #fff;
  border-color: transparent;
}

body[data-page="tandw"] .ndppc-tandw-tab-row button.active span {
  background: rgba(255, 255, 255, 0.16);
  color: #fff;
}

body[data-page="tandw"] .ndppc-tandw-section-head {
  display: grid;
  gap: 0.2rem;
  margin-bottom: 0.75rem;
}

body[data-page="tandw"] .ndppc-tandw-section-head h2 {
  margin: 0;
  font-size: clamp(1.25rem, 1.6vw, 1.5rem);
  line-height: 1.1;
}

body[data-page="tandw"] .ndppc-tandw-group-panel {
  display: grid;
  gap: 0.7rem;
}

body[data-page="tandw"] .ndppc-tandw-record-stack {
  display: grid;
  gap: 0.95rem;
}

body[data-page="tandw"] .ndppc-tandw-record-card {
  display: grid;
  gap: 0.9rem;
  padding: 1.15rem 1.2rem 1.1rem;
  border-radius: 24px;
  border: 1px solid rgba(18, 44, 34, 0.08);
  box-shadow: 0 18px 40px rgba(18, 44, 34, 0.06);
}

body[data-page="tandw"] .ndppc-tandw-record-card--course {
  background:
    radial-gradient(circle at top right, rgba(27, 106, 75, 0.12), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(232, 241, 235, 0.99) 100%);
}

body[data-page="tandw"] .ndppc-tandw-record-card--workshop {
  background:
    radial-gradient(circle at top right, rgba(140, 109, 49, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(247, 239, 219, 0.99) 100%);
}

body[data-page="tandw"] .ndppc-tandw-record-card--lead {
  padding: 1.35rem 1.35rem 1.25rem;
  border-radius: 28px;
}

body[data-page="tandw"] .ndppc-tandw-record-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

body[data-page="tandw"] .ndppc-tandw-record-meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem 0.9rem;
}

body[data-page="tandw"] .ndppc-tandw-record-meta small {
  color: rgba(15, 43, 30, 0.62);
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

body[data-page="tandw"] .ndppc-tandw-record-icon,
body[data-page="tandw"] .ndppc-tandw-record-year {
  min-width: 56px;
  height: 56px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 18px;
  background: rgba(18, 44, 34, 0.08);
  color: var(--ndppc-primary-dark);
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
}

body[data-page="tandw"] .ndppc-tandw-record-card--workshop .ndppc-tandw-record-year {
  min-width: 76px;
  padding: 0 0.9rem;
}

body[data-page="tandw"] .ndppc-tandw-record-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  line-height: 1.16;
}

body[data-page="tandw"] .ndppc-tandw-record-venue {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.55rem;
  color: rgba(15, 43, 30, 0.78);
  line-height: 1.58;
}

body[data-page="tandw"] .ndppc-tandw-record-venue i {
  color: var(--ndppc-accent);
  margin-top: 0.18rem;
}

@media (max-width: 991px) {
  body[data-page="tandw"] .ndppc-tandw-groups-band {
    padding-top: 14px;
  }

  body[data-page="tandw"] .ndppc-tandw-panel-shell {
    padding: 1.15rem;
  }

  body[data-page="tandw"] .ndppc-tandw-tab-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  body[data-page="tandw"] .ndppc-tandw-tab-row button {
    min-width: 0;
  }
}

@media (max-width: 767px) {
  body[data-page="tandw"] .ndppc-tandw-overview-copy,
  body[data-page="tandw"] .ndppc-tandw-stat-card,
  body[data-page="tandw"] .ndppc-tandw-panel-shell,
  body[data-page="tandw"] .ndppc-tandw-record-card {
    border-radius: 22px;
  }

  body[data-page="tandw"] .ndppc-tandw-panel-shell {
    padding: 1rem;
  }

  body[data-page="tandw"] .ndppc-tandw-groups-band {
    padding-top: 10px;
  }

  body[data-page="tandw"] .ndppc-tandw-tab-row {
    grid-template-columns: 1fr;
  }

  body[data-page="tandw"] .ndppc-tandw-record-top {
    align-items: stretch;
    flex-direction: column;
  }
}

body[data-page="software"] .banner.ndppc-software-banner {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

body[data-page="software"] .banner.ndppc-software-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="software"] .banner.ndppc-software-banner .banner_inner {
  padding: 0 !important;
  min-height: 0 !important;
  overflow: visible;
  background: transparent !important;
  background-image: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

body[data-page="software"] .banner_content.ndppc-software-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="software"] .ndppc-software-banner-frame {
  position: relative;
  width: 100%;
  overflow: hidden;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
}

body[data-page="software"] .ndppc-software-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  object-fit: cover;
  object-position: center center;
  display: block;
}

body[data-page="software"] .ndppc-software-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="software"] .ndppc-software-banner-copy {
  display: grid;
  gap: 1rem;
  width: 100%;
  max-width: none;
  margin: 0;
  position: absolute;
  inset: 0;
  align-content: center;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="software"] .ndppc-software-banner-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0;
  font-size: 0.95rem;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="software"] .ndppc-software-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="software"] .ndppc-software-banner-copy h1 {
  margin: 0;
  max-width: none;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.04;
}

body[data-page="software"] .ndppc-software-status-band,
body[data-page="software"] .ndppc-software-links-band {
  padding-top: 28px;
  padding-bottom: 30px;
}

body[data-page="blog"] .banner.ndppc-blog-banner {
  padding-top: 0;
  padding-bottom: 0;
  padding-left: 0;
  padding-right: 0;
  margin-top: 0;
}

body[data-page="blog"] .banner.ndppc-blog-banner .container {
  max-width: 100%;
  width: 100%;
  padding-left: 0;
  padding-right: 0;
}

body[data-page="blog"] .banner.ndppc-blog-banner .banner_inner {
  padding: 0 !important;
  min-height: 0 !important;
  overflow: visible;
  background: transparent !important;
  background-image: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

body[data-page="blog"] .banner_content.ndppc-blog-banner-grid {
  width: 100%;
  max-width: none;
  margin: 0;
  grid-template-columns: 1fr;
}

body[data-page="blog"] .ndppc-blog-banner-frame {
  position: relative;
  width: 100%;
  overflow: hidden;
  min-height: 120px;
  max-height: 170px;
  margin: 0;
}

body[data-page="blog"] .ndppc-blog-banner-frame img {
  width: 100%;
  height: 100%;
  min-height: 120px;
  max-height: 170px;
  object-fit: cover;
  object-position: center center;
  display: block;
}

body[data-page="blog"] .ndppc-blog-banner-frame::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(250, 247, 240, 0.97) 0%, rgba(250, 247, 240, 0.95) 34%, rgba(250, 247, 240, 0.84) 58%, rgba(250, 247, 240, 0.7) 100%);
  z-index: 1;
}

body[data-page="blog"] .ndppc-blog-banner-copy {
  display: grid;
  gap: 1rem;
  width: 100%;
  max-width: none;
  margin: 0;
  position: absolute;
  inset: 0;
  align-content: center;
  padding-top: 1.45rem;
  padding-bottom: 1.45rem;
  padding-left: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  padding-right: max(1.1rem, calc((100vw - 1320px) / 2 + 0.75rem));
  z-index: 2;
}

body[data-page="blog"] .ndppc-blog-banner-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0;
  font-size: 0.95rem;
  color: var(--ndppc-copy);
  font-weight: 600;
}

body[data-page="blog"] .ndppc-blog-banner-breadcrumbs a {
  color: var(--ndppc-primary);
}

body[data-page="blog"] .ndppc-blog-banner-copy h1 {
  margin: 0;
  max-width: none;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.7rem, 2.45vw, 2.45rem);
  line-height: 1.04;
}

body[data-page="blog"] .ndppc-blog-visual-band {
  padding-top: 24px;
  padding-bottom: 34px;
}

body[data-page="blog"] .ndppc-blog-photo-wall {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="blog"] .ndppc-blog-photo-card {
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid rgba(15, 43, 30, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 242, 231, 0.98) 100%);
  box-shadow: 0 20px 40px rgba(107, 80, 26, 0.06);
}

body[data-page="blog"] .ndppc-blog-photo-card img {
  width: 100%;
  height: 260px;
  display: block;
  object-fit: cover;
}

body[data-page="blog"] .ndppc-blog-photo-card--lead {
  grid-column: span 2;
  grid-row: span 2;
}

body[data-page="blog"] .ndppc-blog-photo-card--lead img {
  height: 100%;
  min-height: 540px;
}

body[data-page="blog"] .ndppc-blog-overview-band {
  padding-top: 28px;
  padding-bottom: 18px;
}

body[data-page="blog"] .ndppc-blog-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(280px, 0.9fr);
  gap: 1rem;
  align-items: stretch;
}

body[data-page="blog"] .ndppc-blog-overview-copy,
body[data-page="blog"] .ndppc-blog-stat-card,
body[data-page="blog"] .ndppc-blog-feature-card,
body[data-page="blog"] .ndppc-blog-visit-card {
  border: 1px solid rgba(15, 43, 30, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 242, 231, 0.98) 100%);
  box-shadow: 0 20px 40px rgba(107, 80, 26, 0.06);
}

body[data-page="blog"] .ndppc-blog-overview-copy {
  display: grid;
  gap: 0.9rem;
  align-content: start;
  padding: 1.45rem 1.55rem;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(27, 106, 75, 0.1), transparent 35%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 242, 231, 0.98) 100%);
}

body[data-page="blog"] .ndppc-blog-overview-copy .rounded-pill {
  width: fit-content;
  min-height: 40px;
  padding: 0.55rem 1rem;
  background: #f3ecda;
  color: #8b6414;
}

body[data-page="blog"] .ndppc-blog-overview-copy h2,
body[data-page="blog"] .ndppc-blog-section-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
  line-height: 1.08;
}

body[data-page="blog"] .ndppc-blog-overview-stats {
  display: grid;
  gap: 1rem;
}

body[data-page="blog"] .ndppc-blog-stat-card {
  border-radius: 28px;
  padding: 1.35rem 1.4rem;
  display: grid;
  gap: 0.5rem;
  align-content: center;
}

body[data-page="blog"] .ndppc-blog-stat-card strong {
  color: var(--ndppc-primary-dark);
  font-size: clamp(2rem, 3vw, 2.8rem);
  line-height: 1;
}

body[data-page="blog"] .ndppc-blog-stat-card span {
  color: #5b6672;
  font-weight: 600;
  line-height: 1.45;
}

body[data-page="blog"] .ndppc-blog-feature-band {
  padding-top: 8px;
  padding-bottom: 20px;
}

body[data-page="blog"] .ndppc-blog-section-head {
  margin-bottom: 1rem;
}

body[data-page="blog"] .ndppc-blog-feature-grid {
  display: grid;
  grid-template-columns: 1.2fr 0.9fr 0.9fr;
  gap: 1rem;
}

body[data-page="blog"] .ndppc-blog-feature-card,
body[data-page="blog"] .ndppc-blog-visit-card {
  overflow: hidden;
  border-radius: 28px;
}

body[data-page="blog"] .ndppc-blog-feature-card img,
body[data-page="blog"] .ndppc-blog-visit-card img {
  width: 100%;
  display: block;
  object-fit: cover;
}

body[data-page="blog"] .ndppc-blog-feature-card img {
  height: 280px;
}

body[data-page="blog"] .ndppc-blog-feature-card--lead img {
  height: 100%;
  min-height: 280px;
}

body[data-page="blog"] .ndppc-blog-feature-card {
  display: grid;
  grid-template-rows: auto 1fr;
}

body[data-page="blog"] .ndppc-blog-feature-card--lead {
  grid-row: span 2;
}

body[data-page="blog"] .ndppc-blog-feature-copy,
body[data-page="blog"] .ndppc-blog-visit-copy {
  display: grid;
  gap: 0.7rem;
  padding: 1.15rem 1.2rem 1.25rem;
}

body[data-page="blog"] .ndppc-blog-feature-copy .rounded-pill,
body[data-page="blog"] .ndppc-blog-visit-copy .rounded-pill {
  width: fit-content;
  background: #f3ecda;
  color: #8b6414;
}

body[data-page="blog"] .ndppc-blog-feature-copy h3,
body[data-page="blog"] .ndppc-blog-visit-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.35rem;
  line-height: 1.15;
}

body[data-page="blog"] .ndppc-blog-gallery-band {
  padding-top: 10px;
  padding-bottom: 34px;
}

body[data-page="blog"] .ndppc-blog-gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="blog"] .ndppc-blog-visit-card img {
  height: 230px;
}

@media (max-width: 767px) {
  body[data-page="blog"] .ndppc-blog-visual-band {
    padding-top: 20px;
    padding-bottom: 24px;
  }

  body[data-page="blog"] .ndppc-blog-overview-band {
    padding-top: 22px;
  }

  body[data-page="blog"] .ndppc-blog-banner-frame,
  body[data-page="blog"] .ndppc-blog-banner-frame img {
    min-height: 88px;
  }

  body[data-page="blog"] .ndppc-blog-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="blog"] .ndppc-blog-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="blog"] .ndppc-blog-photo-wall {
    grid-template-columns: 1fr;
  }

  body[data-page="blog"] .ndppc-blog-photo-card--lead {
    grid-column: auto;
    grid-row: auto;
  }

  body[data-page="blog"] .ndppc-blog-photo-card img,
  body[data-page="blog"] .ndppc-blog-photo-card--lead img {
    min-height: 0;
    height: 220px;
  }

  body[data-page="blog"] .ndppc-blog-overview-grid,
  body[data-page="blog"] .ndppc-blog-feature-grid,
  body[data-page="blog"] .ndppc-blog-gallery-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="blog"] .ndppc-blog-overview-copy,
  body[data-page="blog"] .ndppc-blog-stat-card,
  body[data-page="blog"] .ndppc-blog-feature-copy,
  body[data-page="blog"] .ndppc-blog-visit-copy {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  body[data-page="blog"] .ndppc-blog-feature-card--lead {
    grid-row: auto;
  }

  body[data-page="blog"] .ndppc-blog-feature-card img,
  body[data-page="blog"] .ndppc-blog-feature-card--lead img,
  body[data-page="blog"] .ndppc-blog-visit-card img {
    min-height: 0;
    height: 220px;
  }
}

body[data-page="software"] .ndppc-software-status-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(320px, 0.98fr);
  gap: 1rem;
  align-items: stretch;
}

body[data-page="software"] .ndppc-software-status-copy,
body[data-page="software"] .ndppc-software-status-card,
body[data-page="software"] .ndppc-software-links-head {
  border: 1px solid rgba(15, 43, 30, 0.08);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 242, 231, 0.98) 100%);
  box-shadow: 0 20px 40px rgba(107, 80, 26, 0.06);
}

body[data-page="software"] .ndppc-software-status-copy {
  display: grid;
  gap: 0.9rem;
  align-content: start;
  padding: 1.45rem 1.55rem;
  border-radius: 28px;
  background:
    radial-gradient(circle at top right, rgba(27, 106, 75, 0.1), transparent 35%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 242, 231, 0.98) 100%);
}

body[data-page="software"] .ndppc-software-status-copy--solo {
  max-width: 760px;
  margin: 0 auto;
  justify-items: center;
  text-align: center;
}

body[data-page="software"] .ndppc-software-status-copy .rounded-pill,
body[data-page="software"] .ndppc-software-links-head .rounded-pill {
  background: #f3ecda;
  color: #8b6414;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="software"] .ndppc-software-status-copy h2,
body[data-page="software"] .ndppc-software-links-head h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2vw, 2.08rem);
  line-height: 1.12;
}

body[data-page="software"] .ndppc-software-status-copy p,
body[data-page="software"] .ndppc-software-status-card p {
  margin: 0;
  color: rgba(15, 43, 30, 0.8);
  line-height: 1.72;
}

body[data-page="software"] .ndppc-software-status-grid {
  display: grid;
  gap: 1rem;
}

body[data-page="software"] .ndppc-software-status-card {
  display: grid;
  gap: 0.7rem;
  align-content: start;
  padding: 1.2rem 1.2rem 1.1rem;
  border-radius: 24px;
}

body[data-page="software"] .ndppc-software-status-card .material-symbols-outlined {
  width: 54px;
  height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: rgba(27, 106, 75, 0.08);
  color: var(--ndppc-primary);
  font-size: 1.55rem;
}

body[data-page="software"] .ndppc-software-status-card h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.15rem;
  line-height: 1.2;
}

body[data-page="software"] .ndppc-software-links-head {
  display: grid;
  gap: 0.7rem;
  padding: 1.3rem 1.4rem;
  border-radius: 28px;
  margin-bottom: 1rem;
}

@media (max-width: 991px) {
  body[data-page="software"] .ndppc-software-status-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="software"] .ndppc-software-banner-frame,
  body[data-page="software"] .ndppc-software-banner-frame img {
    min-height: 88px;
  }

  body[data-page="software"] .ndppc-software-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="software"] .ndppc-software-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="software"] .ndppc-software-status-band,
  body[data-page="software"] .ndppc-software-links-band {
    padding-top: 22px;
    padding-bottom: 24px;
  }

  body[data-page="software"] .ndppc-software-status-copy,
  body[data-page="software"] .ndppc-software-status-card,
  body[data-page="software"] .ndppc-software-links-head {
    padding: 1.1rem 1rem;
    border-radius: 22px;
  }
}

body[data-page="contact"] .ndppc-contact-overview-copy h2,
body[data-page="contact"] .ndppc-contact-record h2,
body[data-page="contact"] .ndppc-contact-form-head h2,
body[data-page="contact"] .ndppc-contact-map-copy h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
  line-height: 1.1;
}

body[data-page="contact"] .ndppc-contact-overview-copy p,
body[data-page="contact"] .ndppc-contact-record-list p,
body[data-page="contact"] .ndppc-contact-map-copy p,
body[data-page="contact"] .ndppc-contact-quick-card p,
body[data-page="contact"] .ndppc-contact-quick-card a {
  margin: 0;
  color: rgba(15, 43, 30, 0.82);
  line-height: 1.74;
}

body[data-page="contact"] .ndppc-contact-quick-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

body[data-page="contact"] .ndppc-contact-quick-card {
  display: grid;
  gap: 0.55rem;
  align-content: start;
  min-height: 160px;
  padding: 1.15rem 1.15rem 1.1rem;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99) 0%, rgba(238, 246, 242, 0.98) 100%);
}

body[data-page="contact"] .ndppc-contact-quick-card .material-symbols-outlined {
  width: 48px;
  height: 48px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  background: rgba(15, 43, 30, 0.08);
  color: var(--ndppc-primary-dark);
  font-size: 1.3rem;
}

body[data-page="contact"] .ndppc-contact-quick-card strong,
body[data-page="contact"] .ndppc-contact-record-list strong {
  color: var(--ndppc-primary-dark);
}

body[data-page="contact"] .ndppc-contact-quick-stack {
  display: grid;
  gap: 0.2rem;
}

body[data-page="contact"] .ndppc-contact-main-grid,
body[data-page="contact"] .ndppc-contact-map-layout {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(340px, 1.05fr);
  gap: 1.2rem;
  align-items: stretch;
}

body[data-page="contact"] .ndppc-contact-main-grid-single {
  grid-template-columns: 1fr;
}

body[data-page="contact"] .ndppc-contact-record {
  display: grid;
  gap: 0.9rem;
  align-content: start;
  padding: 1.4rem 1.45rem 1.35rem;
}

body[data-page="contact"] .ndppc-contact-record-list {
  display: grid;
  gap: 0.85rem;
}

body[data-page="contact"] .ndppc-contact-record-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

body[data-page="contact"] .ndppc-contact-form-shell {
  display: grid;
  gap: 0.9rem;
  padding: 1.35rem;
}

body[data-page="contact"] .ndppc-contact-form-head {
  display: grid;
  gap: 0.6rem;
}

body[data-page="contact"] .ndppc-contact-form-frame,
body[data-page="contact"] .ndppc-contact-map-frame {
  padding: 0.8rem;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.86);
}

body[data-page="contact"] .ndppc-contact-form-frame > div {
  width: 100%;
}

body[data-page="contact"] .ndppc-contact-form-frame iframe,
body[data-page="contact"] .ndppc-contact-map-frame iframe {
  display: block;
  width: 100% !important;
  min-height: 420px;
  border: 0;
  border-radius: 18px;
}

body[data-page="contact"] .ndppc-contact-map-copy {
  display: grid;
  gap: 0.85rem;
  align-content: start;
  padding: 1.45rem 1.55rem;
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(20, 53, 38, 0.95) 0%, rgba(26, 69, 49, 0.93) 58%, rgba(184, 146, 66, 0.88) 100%);
}

body[data-page="contact"] .ndppc-contact-map-copy h2,
body[data-page="contact"] .ndppc-contact-map-copy p {
  color: #fff;
}

body[data-page="contact"] .ndppc-contact-map-copy .rounded-pill {
  background: rgba(255, 255, 255, 0.16);
  color: #fff5da;
}

@media (max-width: 991px) {
  body[data-page="contact"] .ndppc-contact-banner-frame,
  body[data-page="contact"] .ndppc-contact-banner-frame img {
    min-height: 102px;
  }

  body[data-page="contact"] .ndppc-contact-overview,
  body[data-page="contact"] .ndppc-contact-main-grid,
  body[data-page="contact"] .ndppc-contact-map-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="contact"] .ndppc-contact-banner-frame,
  body[data-page="contact"] .ndppc-contact-banner-frame img {
    min-height: 88px;
  }

  body[data-page="contact"] .ndppc-contact-banner-copy {
    gap: 0.4rem;
    padding-top: 0.65rem;
    padding-bottom: 0.65rem;
    padding-left: 1.1rem;
    padding-right: 1.1rem;
  }

  body[data-page="contact"] .ndppc-contact-banner-copy h1 {
    font-size: 1.65rem;
  }

  body[data-page="contact"] .ndppc-contact-overview-band,
  body[data-page="contact"] .ndppc-contact-main-band,
  body[data-page="contact"] .ndppc-contact-map-band {
    padding-top: 22px;
    padding-bottom: 24px;
  }

  body[data-page="contact"] .ndppc-contact-overview-copy,
  body[data-page="contact"] .ndppc-contact-record,
  body[data-page="contact"] .ndppc-contact-form-shell,
  body[data-page="contact"] .ndppc-contact-map-copy,
  body[data-page="contact"] .ndppc-contact-map-frame,
  body[data-page="contact"] .ndppc-contact-quick-card {
    padding: 1.1rem 1rem;
    border-radius: 22px;
  }

  body[data-page="contact"] .ndppc-contact-quick-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="contact"] .ndppc-contact-form-frame iframe,
  body[data-page="contact"] .ndppc-contact-map-frame iframe {
    min-height: 320px;
  }
}

/* Final Contact Layout Override */
body[data-page="contact"] .ndppc-contact-connect-band {
  padding-top: 18px;
  padding-bottom: 20px;
}

body[data-page="contact"] .ndppc-contact-connect-grid {
  display: grid;
  grid-template-columns: minmax(320px, 0.72fr) minmax(0, 1.28fr);
  gap: 1.5rem;
  align-items: stretch;
}

body[data-page="contact"] .ndppc-contact-info-card,
body[data-page="contact"] .ndppc-contact-form-shell,
body[data-page="contact"] .ndppc-contact-map-copy,
body[data-page="contact"] .ndppc-contact-map-frame {
  border: 1px solid rgba(18, 44, 34, 0.06);
  background: var(--ndppc-surface);
  box-shadow: 0 16px 34px rgba(18, 44, 34, 0.05);
}

body[data-page="contact"] .ndppc-contact-info-card {
  display: grid;
  align-content: start;
  gap: 1.2rem;
  padding: 2.1rem 1.9rem 1.85rem;
  border-radius: 0;
  min-height: 100%;
  border: 0;
  background: transparent;
  box-shadow: none;
}

body[data-page="contact"] .ndppc-contact-info-card h2 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(2rem, 2.8vw, 2.75rem);
  line-height: 1.02;
}

body[data-page="contact"] .ndppc-contact-info-card > p {
  margin: 0;
  color: rgba(15, 43, 30, 0.74);
  line-height: 1.58;
  font-size: 1.02rem;
}

body[data-page="contact"] .ndppc-contact-info-stack {
  display: grid;
  margin-top: 0.1rem;
}

body[data-page="contact"] .ndppc-contact-info-row {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
  padding: 1.35rem 0;
  border-top: 1px solid rgba(20, 53, 38, 0.1);
}

body[data-page="contact"] .ndppc-contact-info-row:first-child {
  border-top: 0;
}

body[data-page="contact"] .ndppc-contact-info-row .material-symbols-outlined {
  color: #28b463;
  font-size: 2.1rem;
  line-height: 1;
  padding-top: 0.08rem;
}

body[data-page="contact"] .ndppc-contact-info-row strong {
  display: block;
  margin-bottom: 0.35rem;
  color: var(--ndppc-primary-dark);
  font-size: 1rem;
}

body[data-page="contact"] .ndppc-contact-info-row p,
body[data-page="contact"] .ndppc-contact-info-row a {
  margin: 0;
  color: rgba(15, 43, 30, 0.78);
  line-height: 1.62;
  font-size: 1.02rem;
  text-decoration: none;
}

body[data-page="contact"] .ndppc-contact-info-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  padding-top: 0.3rem;
}

body[data-page="contact"] .ndppc-contact-info-actions .ndppc-inline-link {
  color: #2d8055;
  font-size: 0.96rem;
  font-weight: 600;
}

body[data-page="contact"] .ndppc-contact-form-shell {
  border-radius: 0;
  padding: 0;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(247, 244, 237, 0.98) 0%, rgba(236, 227, 207, 0.56) 100%);
  min-height: 100%;
  align-self: stretch;
}

body[data-page="contact"] .ndppc-contact-form-head {
  display: none;
}

body[data-page="contact"] .ndppc-contact-form-frame {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  height: 100%;
  overflow: hidden;
}

body[data-page="contact"] .ndppc-contact-form-frame > div {
  width: 100%;
  min-height: 0;
  height: 100%;
}

body[data-page="contact"] .ndppc-contact-form-frame iframe {
  display: block;
  width: 100% !important;
  height: 100% !important;
  min-height: 0;
  border-radius: 0;
}

body[data-page="contact"] .ndppc-contact-map-band {
  padding-top: 8px;
}

body[data-page="contact"] .ndppc-contact-map-layout {
  display: block;
}

body[data-page="contact"] .ndppc-contact-map-frame {
  padding: 0;
  border-radius: 0;
  background: transparent;
  border: 0;
  box-shadow: none;
}

body[data-page="contact"] .ndppc-contact-map-frame-wide {
  width: 100%;
}

body[data-page="contact"] .ndppc-contact-map-frame iframe {
  border-radius: 0;
  min-height: 360px;
}

@media (max-width: 991px) {
  body[data-page="contact"] .ndppc-contact-connect-grid {
    grid-template-columns: 1fr;
  }

  body[data-page="contact"] .ndppc-contact-form-shell,
  body[data-page="contact"] .ndppc-contact-form-frame {
    height: auto !important;
  }

  body[data-page="contact"] .ndppc-contact-form-frame {
    overflow: visible;
  }

  body[data-page="contact"] .ndppc-contact-form-frame > div {
    min-height: 0;
    height: auto;
  }

  body[data-page="contact"] .ndppc-contact-form-frame iframe {
    min-height: 0;
    height: auto !important;
  }
}

@media (max-width: 767px) {
  body[data-page="contact"] .ndppc-contact-connect-band {
    padding-top: 20px;
    padding-bottom: 16px;
  }

  body[data-page="contact"] .ndppc-contact-info-card {
    padding: 1.2rem 1rem;
  }

  body[data-page="contact"] .ndppc-contact-info-card h2 {
    font-size: 1.95rem;
  }

  body[data-page="contact"] .ndppc-contact-info-row {
    grid-template-columns: 42px minmax(0, 1fr);
    gap: 0.85rem;
    padding: 1rem 0;
  }

  body[data-page="contact"] .ndppc-contact-info-row .material-symbols-outlined {
    font-size: 1.7rem;
  }

  body[data-page="contact"] .ndppc-contact-form-frame > div,
  body[data-page="contact"] .ndppc-contact-form-frame iframe {
    min-height: 1530px;
  }

  body[data-page="contact"] .ndppc-contact-map-frame iframe {
    min-height: 260px;
  }
}

body[data-page="mission"] .ndppc-mission2-overview-band,
body[data-page="mission"] .ndppc-mission2-pillars-band,
body[data-page="mission"] .ndppc-mission2-goals-band {
  padding-top: 26px;
  padding-bottom: 30px;
}

body[data-page="mission"] .ndppc-mission2-tone-emerald {
  --ndppc-mission2-accent: #1f6a4d;
  --ndppc-mission2-soft: rgba(228, 241, 234, 0.98);
}

body[data-page="mission"] .ndppc-mission2-tone-amber {
  --ndppc-mission2-accent: #a56d1e;
  --ndppc-mission2-soft: rgba(247, 239, 219, 0.98);
}

body[data-page="mission"] .ndppc-mission2-tone-violet {
  --ndppc-mission2-accent: #6f5aa8;
  --ndppc-mission2-soft: rgba(235, 232, 245, 0.98);
}

body[data-page="mission"] .ndppc-mission2-tone-slate {
  --ndppc-mission2-accent: #3b6478;
  --ndppc-mission2-soft: rgba(231, 239, 244, 0.98);
}

body[data-page="mission"] .ndppc-mission2-overview {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.92fr);
  gap: 1.2rem;
  align-items: stretch;
}

body[data-page="mission"] .ndppc-mission2-overview-copy,
body[data-page="mission"] .ndppc-mission2-theme-card,
body[data-page="mission"] .ndppc-mission2-pillar-card,
body[data-page="mission"] .ndppc-mission2-goal-card {
  border: 1px solid rgba(20, 53, 38, 0.08);
  box-shadow: 0 22px 40px rgba(20, 53, 38, 0.06);
}

body[data-page="mission"] .ndppc-mission2-overview-copy {
  padding: 1.45rem 1.5rem;
  border-radius: 30px;
  background:
    radial-gradient(circle at top right, rgba(184, 146, 66, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, rgba(247, 242, 231, 0.98) 100%);
}

body[data-page="mission"] .ndppc-mission2-overview-copy .rounded-pill,
body[data-page="mission"] .ndppc-mission2-section-head .rounded-pill,
body[data-page="mission"] .ndppc-mission2-pillar-meta .rounded-pill,
body[data-page="mission"] .ndppc-mission2-goal-copy .rounded-pill {
  background: #f3ecda;
  color: #8b6414;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

body[data-page="mission"] .ndppc-mission2-overview-copy h2,
body[data-page="mission"] .ndppc-mission2-section-head h2 {
  margin: 0.9rem 0 0;
  color: var(--ndppc-primary-dark);
  font-size: clamp(1.56rem, 2.05vw, 2.15rem);
  line-height: 1.08;
}

body[data-page="mission"] .ndppc-mission2-overview-copy p,
body[data-page="mission"] .ndppc-mission2-pillar-copy p,
body[data-page="mission"] .ndppc-mission2-goal-copy p {
  margin: 0;
  color: rgba(15, 43, 30, 0.8);
  line-height: 1.78;
}

body[data-page="mission"] .ndppc-mission2-overview-copy p {
  margin-top: 0.95rem;
}

body[data-page="mission"] .ndppc-mission2-theme-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.95rem;
}

body[data-page="mission"] .ndppc-mission2-theme-card {
  border-radius: 24px;
  padding: 1.15rem 1.1rem 1rem;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, var(--ndppc-mission2-soft) 100%);
  display: grid;
  gap: 0.55rem;
  align-content: start;
}

body[data-page="mission"] .ndppc-mission2-theme-icon,
body[data-page="mission"] .ndppc-mission2-pillar-icon,
body[data-page="mission"] .ndppc-mission2-goal-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: color-mix(in srgb, var(--ndppc-mission2-accent) 14%, #ffffff);
  color: var(--ndppc-mission2-accent);
  font-size: 1.28rem;
  line-height: 1;
}

body[data-page="mission"] .ndppc-mission2-theme-card strong {
  color: var(--ndppc-mission2-accent);
  font-size: 1.6rem;
  line-height: 1;
}

body[data-page="mission"] .ndppc-mission2-theme-card span:last-child {
  color: var(--ndppc-primary-dark);
  font-weight: 700;
  line-height: 1.35;
}

body[data-page="mission"] .ndppc-mission2-section-head {
  display: grid;
  gap: 0.18rem;
  margin-bottom: 1.2rem;
}

body[data-page="mission"] .ndppc-mission2-pillar-grid,
body[data-page="mission"] .ndppc-mission2-goal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem 1.1rem;
}

body[data-page="mission"] .ndppc-mission2-pillar-card,
body[data-page="mission"] .ndppc-mission2-goal-card {
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.98) 0%, var(--ndppc-mission2-soft) 100%);
  transition: transform 180ms ease, box-shadow 180ms ease;
}

body[data-page="mission"] .ndppc-mission2-pillar-card:hover,
body[data-page="mission"] .ndppc-mission2-goal-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 28px 46px rgba(20, 53, 38, 0.09);
}

body[data-page="mission"] .ndppc-mission2-pillar-card {
  padding: 1.25rem 1.25rem 1.2rem;
  display: grid;
  gap: 1rem;
}

body[data-page="mission"] .ndppc-mission2-pillar-top {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  gap: 0.9rem;
  align-items: start;
}

body[data-page="mission"] .ndppc-mission2-pillar-meta {
  display: grid;
  gap: 0.45rem;
}

body[data-page="mission"] .ndppc-mission2-pillar-index {
  color: var(--ndppc-mission2-accent);
  font-weight: 800;
  font-size: 0.92rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

body[data-page="mission"] .ndppc-mission2-pillar-copy {
  display: grid;
  gap: 0.65rem;
}

body[data-page="mission"] .ndppc-mission2-pillar-copy h3 {
  margin: 0;
  color: var(--ndppc-primary-dark);
  font-size: 1.34rem;
  line-height: 1.22;
}

body[data-page="mission"] .ndppc-mission2-goals-band {
  background:
    linear-gradient(180deg, rgba(243, 236, 218, 0.42) 0%, rgba(255, 255, 255, 0.96) 100%);
}

body[data-page="mission"] .ndppc-mission2-goal-card {
  padding: 1.2rem 1.2rem 1.15rem;
  display: grid;
  grid-template-columns: 84px minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

body[data-page="mission"] .ndppc-mission2-goal-side {
  display: grid;
  gap: 0.65rem;
  justify-items: center;
}

body[data-page="mission"] .ndppc-mission2-goal-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  border-radius: 20px;
  background: color-mix(in srgb, var(--ndppc-mission2-accent) 15%, #ffffff);
  color: var(--ndppc-mission2-accent);
  font-size: 1.45rem;
  font-weight: 800;
  line-height: 1;
}

body[data-page="mission"] .ndppc-mission2-goal-copy {
  display: grid;
  gap: 0.75rem;
}

@media (max-width: 991px) {
  body[data-page="mission"] .ndppc-mission2-overview {
    grid-template-columns: 1fr;
  }

  body[data-page="mission"] .ndppc-mission2-pillar-grid,
  body[data-page="mission"] .ndppc-mission2-goal-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 767px) {
  body[data-page="mission"] .ndppc-mission2-overview-band,
  body[data-page="mission"] .ndppc-mission2-pillars-band,
  body[data-page="mission"] .ndppc-mission2-goals-band {
    padding-top: 22px;
    padding-bottom: 24px;
  }

  body[data-page="mission"] .ndppc-mission2-overview-copy,
  body[data-page="mission"] .ndppc-mission2-pillar-card,
  body[data-page="mission"] .ndppc-mission2-goal-card {
    padding: 1.05rem 1rem;
    border-radius: 22px;
  }

  body[data-page="mission"] .ndppc-mission2-theme-grid {
    grid-template-columns: 1fr 1fr;
    gap: 0.8rem;
  }

  body[data-page="mission"] .ndppc-mission2-theme-card {
    padding: 1rem 0.92rem 0.95rem;
  }

  body[data-page="mission"] .ndppc-mission2-pillar-top,
  body[data-page="mission"] .ndppc-mission2-goal-card {
    grid-template-columns: 1fr;
  }

  body[data-page="mission"] .ndppc-mission2-goal-side {
    justify-items: start;
    grid-auto-flow: column;
    justify-content: start;
    align-items: center;
  }
}

@media (max-width: 991px) {
  .ndppc-site-header .container-fluid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
    row-gap: 0.55rem;
  }

  .ndppc-site-header .navbar-brand,
  .ndppc-navbar-brand {
    max-width: 100% !important;
    width: 100%;
    margin-right: 0 !important;
  }

  .ndppc-site-header .navbar-toggler {
    justify-self: start;
    margin-left: calc(58px + 0.85rem);
  }

  .ndppc-site-header .navbar-collapse {
    width: 100%;
    margin-top: 0.3rem;
  }
}

@media (max-width: 767px) {
  .ndppc-brand-lockup {
    gap: 0.7rem;
  }

  .ndppc-brand-logo {
    width: 46px;
    height: 46px;
    flex: 0 0 46px;
  }

  .ndppc-navbar-brand .ndppc-brand-copy strong {
    font-size: 0.9rem;
    line-height: 1.18;
  }

  .ndppc-navbar-brand .ndppc-brand-copy small {
    font-size: 0.72rem;
    line-height: 1.12;
  }

  .ndppc-site-header .navbar-toggler {
    justify-self: center;
    margin-left: 0;
    padding: 0.4rem 0.58rem;
  }

  .ndppc-site-header .navbar-toggler-icon {
    width: 1.2rem;
    height: 1.2rem;
  }
}
