/* =====================================================
   "AD-BI" Katarzyna Szymaniak — Main Stylesheet
   Domain: nebularplaydeck.com | Entertainment Only
   ===================================================== */

/* --- Variables --- */
:root {
  --npd-navy:        #0a0e1a;
  --npd-dark-blue:   #111828;
  --npd-blue:        #1a2547;
  --npd-violet:      #6b4fa0;
  --npd-violet-lt:   #8b6fc0;
  --npd-cyan:        #4ecdc4;
  --npd-cyan-lt:     #7ee8e2;
  --npd-coral:       #e8886a;
  --npd-sand:        #f0d9c8;
  --npd-white:       #ffffff;
  --npd-grey-lt:     #f4f6fa;
  --npd-grey:        #e2e8f0;
  --npd-grey-mid:    #94a3b8;
  --npd-text:        #2d3748;
  --npd-text-lt:     #64748b;
  --npd-radius:      14px;
  --npd-radius-lg:   24px;
  --npd-shadow:      0 4px 24px rgba(10,14,26,0.12);
  --npd-shadow-lg:   0 8px 48px rgba(10,14,26,0.18);
  --npd-transition:  0.25s ease;
  --npd-max-width:   1260px;
}

/* --- Reset & Base --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'Inter', 'Segoe UI', system-ui, sans-serif;
  color: var(--npd-text);
  background: var(--npd-white);
  line-height: 1.65;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
ul, ol { list-style: none; }

/* --- Typography --- */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Syne', 'Oswald', 'Segoe UI', sans-serif;
  font-weight: 700;
  line-height: 1.15;
  color: var(--npd-navy);
}
h1 { font-size: clamp(2.4rem, 5vw, 4.2rem); letter-spacing: -1px; }
h2 { font-size: clamp(1.8rem, 3.5vw, 2.8rem); }
h3 { font-size: clamp(1.2rem, 2.5vw, 1.7rem); }
h4 { font-size: 1.2rem; }
p  { margin-bottom: 1rem; }

.npd-container {
  max-width: var(--npd-max-width);
  margin: 0 auto;
  padding: 0 1.5rem;
}

.npd-section {
  padding: 5rem 0;
}
.npd-section--dark {
  background: var(--npd-navy);
  color: var(--npd-white);
}
.npd-section--dark h1,
.npd-section--dark h2,
.npd-section--dark h3,
.npd-section--dark h4 { color: var(--npd-white); }

.npd-section--grey  { background: var(--npd-grey-lt); }
.npd-section--blue  { background: var(--npd-blue); color: var(--npd-white); }
.npd-section--blue h1,
.npd-section--blue h2,
.npd-section--blue h3 { color: var(--npd-white); }

.npd-eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 2.5px;
  text-transform: uppercase;
  color: var(--npd-cyan);
  margin-bottom: 0.75rem;
}

.npd-section-title { margin-bottom: 1rem; }
.npd-section-sub   { color: var(--npd-text-lt); font-size: 1.05rem; max-width: 600px; margin-bottom: 2.5rem; }

/* --- Buttons --- */
.npd-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 2rem;
  border-radius: var(--npd-radius);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: var(--npd-transition);
  text-decoration: none;
}
.npd-btn--primary {
  background: var(--npd-violet);
  color: var(--npd-white);
  border-color: var(--npd-violet);
}
.npd-btn--primary:hover {
  background: var(--npd-violet-lt);
  border-color: var(--npd-violet-lt);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(107,79,160,0.35);
}
.npd-btn--outline {
  background: transparent;
  color: var(--npd-cyan);
  border-color: var(--npd-cyan);
}
.npd-btn--outline:hover {
  background: var(--npd-cyan);
  color: var(--npd-navy);
  transform: translateY(-2px);
}
.npd-btn--coral {
  background: var(--npd-coral);
  color: var(--npd-white);
  border-color: var(--npd-coral);
}
.npd-btn--coral:hover {
  background: #d0775a;
  border-color: #d0775a;
  transform: translateY(-2px);
}
.npd-btn--sm { padding: 0.6rem 1.4rem; font-size: 0.85rem; }

/* ========== COOKIE NOTICE ========== */
#npd-cookie-bar {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--npd-navy);
  color: var(--npd-white);
  padding: 1rem 2rem;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
  z-index: 9999;
  border-top: 3px solid var(--npd-cyan);
  font-size: 0.9rem;
}
#npd-cookie-bar.hidden { display: none; }
#npd-cookie-bar p { margin: 0; flex: 1; min-width: 200px; }
#npd-cookie-bar .npd-btn { white-space: nowrap; }

/* ========== AGE GATE ========== */
#npd-age-gate {
  position: fixed;
  inset: 0;
  background: rgba(10,14,26,0.97);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
}
#npd-age-gate.hidden { display: none; }
.npd-age-gate__box {
  background: var(--npd-dark-blue);
  border: 2px solid var(--npd-violet);
  border-radius: var(--npd-radius-lg);
  padding: 3rem 2.5rem;
  max-width: 480px;
  width: 90%;
  text-align: center;
}
.npd-age-gate__icon {
  font-size: 3.5rem;
  margin-bottom: 1rem;
}
.npd-age-gate__box h2 {
  color: var(--npd-white);
  margin-bottom: 0.75rem;
}
.npd-age-gate__box p {
  color: var(--npd-grey-mid);
  font-size: 0.95rem;
  margin-bottom: 1.75rem;
}
.npd-age-gate__actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}
.npd-age-gate__deny {
  background: transparent;
  color: var(--npd-grey-mid);
  border: 1px solid var(--npd-grey-mid);
  border-radius: var(--npd-radius);
  padding: 0.7rem 1.5rem;
  cursor: pointer;
  font-size: 0.9rem;
  transition: var(--npd-transition);
}
.npd-age-gate__deny:hover { color: var(--npd-white); border-color: var(--npd-white); }

/* ========== HEADER ========== */
.npd-header {
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 500;
  background: transparent;
  transition: background var(--npd-transition), box-shadow var(--npd-transition);
}
.npd-header.scrolled {
  background: rgba(10,14,26,0.97);
  backdrop-filter: blur(12px);
  box-shadow: 0 2px 20px rgba(0,0,0,0.3);
}
.npd-header__inner {
  max-width: var(--npd-max-width);
  margin: 0 auto;
  padding: 0 1.5rem;
  height: 70px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}
.npd-logo {
  font-family: 'Syne', 'Oswald', sans-serif;
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--npd-white);
  text-decoration: none;
  letter-spacing: -0.5px;
  white-space: nowrap;
}
.npd-logo span { color: var(--npd-cyan); }

.npd-nav { display: flex; align-items: center; gap: 0.25rem; }
.npd-nav a {
  color: rgba(255,255,255,0.85);
  font-size: 0.88rem;
  font-weight: 600;
  letter-spacing: 0.8px;
  text-transform: uppercase;
  padding: 0.5rem 0.9rem;
  border-radius: 8px;
  transition: var(--npd-transition);
}
.npd-nav a:hover,
.npd-nav a.active { color: var(--npd-cyan); background: rgba(78,205,196,0.1); }

.npd-header__cta { margin-left: 1rem; }

/* Mobile toggle */
.npd-mobile-toggle {
  display: none;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0.4rem;
  color: var(--npd-white);
}
.npd-mobile-toggle svg { width: 28px; height: 28px; }

/* Mobile drawer */
.npd-mobile-nav {
  display: none;
  position: fixed;
  top: 70px; left: 0; right: 0; bottom: 0;
  background: rgba(10,14,26,0.98);
  z-index: 499;
  flex-direction: column;
  padding: 2rem 1.5rem;
  gap: 0.5rem;
  overflow-y: auto;
}
.npd-mobile-nav.open { display: flex; }
.npd-mobile-nav a {
  color: var(--npd-white);
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 1rem 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  transition: color var(--npd-transition);
}
.npd-mobile-nav a:hover { color: var(--npd-cyan); }

@media (max-width: 900px) {
  .npd-nav, .npd-header__cta { display: none; }
  .npd-mobile-toggle { display: flex; }
}

@media (max-width: 425px) {
  .npd-header__inner {
    height: 60px;
    padding: 0 1rem;
  }
  .npd-logo {
    font-size: 1rem;
    letter-spacing: -0.3px;
  }
  .npd-mobile-toggle svg { width: 24px; height: 24px; }
}

/* ========== HERO ========== */
.npd-hero {
  min-height: 100vh;
  background: linear-gradient(135deg, var(--npd-navy) 0%, var(--npd-blue) 50%, #1e1040 100%);
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
  padding-top: 70px;
}
.npd-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 70% 60% at 80% 50%, rgba(107,79,160,0.25) 0%, transparent 70%),
              radial-gradient(ellipse 50% 40% at 20% 80%, rgba(78,205,196,0.15) 0%, transparent 60%);
}
.npd-hero__inner {
  max-width: var(--npd-max-width);
  margin: 0 auto;
  padding: 4rem 1.5rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
  position: relative;
  z-index: 1;
}
.npd-hero__content h1 { color: var(--npd-white); margin-bottom: 1.25rem; }
.npd-hero__content h1 span { color: var(--npd-cyan); }
.npd-hero__content p {
  color: rgba(255,255,255,0.75);
  font-size: 1.15rem;
  max-width: 520px;
  margin-bottom: 2rem;
}
.npd-hero__actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 2.5rem; }
.npd-hero__notice {
  background: rgba(78,205,196,0.12);
  border: 1px solid rgba(78,205,196,0.35);
  border-radius: var(--npd-radius);
  padding: 0.9rem 1.25rem;
  color: rgba(255,255,255,0.8);
  font-size: 0.88rem;
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  max-width: 520px;
}
.npd-hero__notice svg { flex-shrink: 0; color: var(--npd-cyan); width: 18px; height: 18px; margin-top: 1px; }
.npd-hero__image { position: relative; }
.npd-hero__image img {
  border-radius: var(--npd-radius-lg);
  box-shadow: var(--npd-shadow-lg), 0 0 60px rgba(107,79,160,0.3);
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
}
.npd-hero__badge {
  position: absolute;
  bottom: -1.5rem;
  left: -1.5rem;
  background: var(--npd-white);
  border-radius: var(--npd-radius);
  padding: 1rem 1.4rem;
  box-shadow: var(--npd-shadow-lg);
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--npd-navy);
}
.npd-hero__badge-icon { font-size: 1.5rem; }
.npd-hero__stats {
  display: flex;
  gap: 2rem;
  margin-top: 2rem;
  flex-wrap: wrap;
}
.npd-hero__stat { color: var(--npd-white); }
.npd-hero__stat-num { font-size: 1.8rem; font-weight: 800; color: var(--npd-cyan); }
.npd-hero__stat-label { font-size: 0.8rem; color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 1px; }

@media (max-width: 900px) {
  .npd-hero__inner { grid-template-columns: 1fr; gap: 2rem; }
  .npd-hero__image { order: -1; }
  .npd-hero__badge { bottom: -1rem; left: 0.5rem; }
}

/* ========== FEATURES STRIP ========== */
.npd-features-strip {
  background: var(--npd-grey-lt);
  padding: 3rem 0;
  border-top: 3px solid var(--npd-grey);
  border-bottom: 3px solid var(--npd-grey);
}
.npd-features-strip__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  text-align: center;
}
.npd-features-strip__item { padding: 1rem; }
.npd-features-strip__icon {
  font-size: 2rem;
  margin-bottom: 0.5rem;
}
.npd-features-strip__title {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--npd-navy);
}
.npd-features-strip__desc {
  font-size: 0.82rem;
  color: var(--npd-text-lt);
  margin: 0;
}

@media (max-width: 768px) {
  .npd-features-strip__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .npd-features-strip__grid { grid-template-columns: 1fr; }
}

/* ========== ABOUT PLATFORM ========== */
.npd-about-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: center;
}
.npd-about-grid.reverse { direction: rtl; }
.npd-about-grid.reverse > * { direction: ltr; }
.npd-about__image img {
  border-radius: var(--npd-radius-lg);
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
  box-shadow: var(--npd-shadow-lg);
}
.npd-about__list { margin: 1.5rem 0; display: flex; flex-direction: column; gap: 0.75rem; }
.npd-about__list-item {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  font-size: 0.97rem;
}
.npd-about__list-icon {
  width: 22px; height: 22px;
  background: var(--npd-cyan);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 1px;
  color: var(--npd-navy);
  font-weight: 900;
  font-size: 0.75rem;
}

@media (max-width: 768px) {
  .npd-about-grid { 
    grid-template-columns: 1fr !important; 
    gap: 2rem !important; 
  }
  .npd-about-grid.reverse { direction: ltr; }
}

/* ========== GAME THEMES ========== */
.npd-games-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
}
.npd-game-card {
  background: var(--npd-white);
  border-radius: var(--npd-radius-lg);
  overflow: hidden;
  box-shadow: var(--npd-shadow);
  transition: transform var(--npd-transition), box-shadow var(--npd-transition);
}
.npd-game-card:hover {
  transform: translateY(-6px);
  box-shadow: var(--npd-shadow-lg);
}
.npd-game-card__img {
  width: 100%;
  aspect-ratio: 4/3;
  object-fit: cover;
}
.npd-game-card__body { padding: 1.5rem; }
.npd-game-card__tag {
  display: inline-block;
  background: var(--npd-grey-lt);
  color: var(--npd-violet);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 0.25rem 0.7rem;
  border-radius: 99px;
  margin-bottom: 0.6rem;
}
.npd-game-card h3 { font-size: 1.05rem; margin-bottom: 0.5rem; }
.npd-game-card p  { font-size: 0.88rem; color: var(--npd-text-lt); margin: 0; }

@media (max-width: 900px) {
  .npd-games-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .npd-games-grid { grid-template-columns: 1fr; }
}

/* ========== STATS ========== */
.npd-stats-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  text-align: center;
}
.npd-stat-card {
  padding: 2rem 1rem;
}
.npd-stat-card__num {
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 900;
  color: var(--npd-cyan);
  font-family: 'Syne', 'Oswald', sans-serif;
  line-height: 1;
  margin-bottom: 0.4rem;
}
.npd-stat-card__label { font-size: 0.88rem; color: rgba(255,255,255,0.65); }

@media (max-width: 768px) {
  .npd-stats-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 400px) {
  .npd-stats-grid { grid-template-columns: 1fr; }
}

/* ========== HOW IT WORKS ========== */
.npd-steps-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 2rem;
  counter-reset: npd-step;
}
.npd-step-card {
  text-align: center;
  padding: 2rem 1.25rem;
  background: var(--npd-white);
  border-radius: var(--npd-radius-lg);
  box-shadow: var(--npd-shadow);
  position: relative;
}
.npd-step-card::before {
  counter-increment: npd-step;
  content: counter(npd-step);
  position: absolute;
  top: -1rem;
  left: 50%;
  transform: translateX(-50%);
  width: 2.25rem;
  height: 2.25rem;
  background: var(--npd-violet);
  color: var(--npd-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 900;
  font-size: 0.95rem;
}
.npd-step-card__icon { font-size: 2.5rem; margin: 0.5rem 0 1rem; }
.npd-step-card h4 { margin-bottom: 0.5rem; }
.npd-step-card p  { font-size: 0.88rem; color: var(--npd-text-lt); margin: 0; }

@media (max-width: 900px) {
  .npd-steps-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .npd-steps-grid { grid-template-columns: 1fr; }
}

/* ========== VIRTUAL CREDITS ========== */
.npd-credits-box {
  background: linear-gradient(135deg, var(--npd-blue) 0%, #1e1040 100%);
  border-radius: var(--npd-radius-lg);
  padding: 3rem;
  color: var(--npd-white);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3rem;
  align-items: center;
}
.npd-credits-box h2 { color: var(--npd-white); margin-bottom: 1rem; }
.npd-credits-box p  { color: rgba(255,255,255,0.75); }
.npd-credits__items { display: flex; flex-direction: column; gap: 1rem; }
.npd-credits__item {
  background: rgba(255,255,255,0.07);
  border-radius: var(--npd-radius);
  padding: 1rem 1.25rem;
  display: flex;
  align-items: center;
  gap: 1rem;
  border: 1px solid rgba(255,255,255,0.1);
}
.npd-credits__item-icon { font-size: 1.75rem; }
.npd-credits__item-label { font-size: 0.95rem; font-weight: 700; }
.npd-credits__item-desc  { font-size: 0.82rem; color: rgba(255,255,255,0.6); }

@media (max-width: 768px) {
  .npd-credits-box { grid-template-columns: 1fr; padding: 2rem; gap: 2rem; }
}

/* ========== ACHIEVEMENTS ========== */
.npd-badges-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
.npd-badge-card {
  background: var(--npd-white);
  border-radius: var(--npd-radius-lg);
  padding: 2rem 1.25rem;
  text-align: center;
  box-shadow: var(--npd-shadow);
  border: 2px solid transparent;
  transition: border-color var(--npd-transition), transform var(--npd-transition);
}
.npd-badge-card:hover {
  border-color: var(--npd-violet);
  transform: translateY(-4px);
}
.npd-badge-card__icon { font-size: 3rem; margin-bottom: 0.75rem; }
.npd-badge-card h4  { font-size: 0.95rem; margin-bottom: 0.4rem; }
.npd-badge-card p   { font-size: 0.82rem; color: var(--npd-text-lt); margin: 0; }

@media (max-width: 768px) {
  .npd-badges-grid { grid-template-columns: repeat(2, 1fr); }
}

/* ========== RESPONSIBLE ENTERTAINMENT ========== */
.npd-responsible-box {
  background: var(--npd-grey-lt);
  border-left: 5px solid var(--npd-coral);
  border-radius: var(--npd-radius);
  padding: 2rem 2.5rem;
}
.npd-responsible-box h3 { color: var(--npd-navy); margin-bottom: 0.75rem; }
.npd-responsible-box p  { color: var(--npd-text); font-size: 0.97rem; }
.npd-responsible-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 2.5rem;
}
.npd-responsible-item {
  background: var(--npd-white);
  border-radius: var(--npd-radius);
  padding: 1.5rem;
  box-shadow: var(--npd-shadow);
  display: flex;
  gap: 1rem;
}
.npd-responsible-item__icon { font-size: 2rem; flex-shrink: 0; }
.npd-responsible-item h4 { font-size: 0.97rem; margin-bottom: 0.35rem; }
.npd-responsible-item p  { font-size: 0.85rem; color: var(--npd-text-lt); margin: 0; }

@media (max-width: 768px) {
  .npd-responsible-grid { grid-template-columns: 1fr; }
  .npd-responsible-box  { padding: 1.5rem; }
}

/* ========== FAQ ========== */
.npd-faq-list { display: flex; flex-direction: column; gap: 1rem; max-width: 800px; margin: 0 auto; }
.npd-faq-item {
  background: var(--npd-white);
  border-radius: var(--npd-radius);
  box-shadow: var(--npd-shadow);
  overflow: hidden;
}
.npd-faq-item__question {
  width: 100%;
  background: none;
  border: none;
  padding: 1.2rem 1.5rem;
  text-align: left;
  font-size: 1rem;
  font-weight: 700;
  color: var(--npd-navy);
  cursor: pointer;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  transition: color var(--npd-transition);
}
.npd-faq-item__question:hover { color: var(--npd-violet); }
.npd-faq-item__arrow {
  flex-shrink: 0;
  width: 22px; height: 22px;
  transition: transform var(--npd-transition);
}
.npd-faq-item.open .npd-faq-item__arrow { transform: rotate(180deg); }
.npd-faq-item__answer {
  padding: 0 1.5rem;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.35s ease, padding 0.35s ease;
}
.npd-faq-item.open .npd-faq-item__answer {
  max-height: 600px;
  padding: 0 1.5rem 1.2rem;
}
.npd-faq-item__answer p { font-size: 0.95rem; color: var(--npd-text-lt); margin: 0; }

/* ========== CTA SECTION ========== */
.npd-cta-section {
  background: linear-gradient(135deg, var(--npd-violet) 0%, var(--npd-navy) 100%);
  padding: 5rem 0;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.npd-cta-section::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 80% at 50% 50%, rgba(78,205,196,0.1) 0%, transparent 70%);
}
.npd-cta-section__inner { position: relative; z-index: 1; }
.npd-cta-section h2 { color: var(--npd-white); margin-bottom: 1rem; }
.npd-cta-section p  { color: rgba(255,255,255,0.75); max-width: 550px; margin: 0 auto 2rem; font-size: 1.05rem; }
.npd-cta-section .npd-btn { font-size: 1rem; padding: 1rem 2.5rem; }
.npd-cta-section__disclaimer {
  margin-top: 1.5rem;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.5);
}

/* ========== LEADERBOARD ========== */
.npd-leaderboard-wrapper {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.npd-leaderboard-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--npd-white);
  border-radius: var(--npd-radius-lg);
  overflow: hidden;
  box-shadow: var(--npd-shadow);
  margin-top: 3rem;
  min-width: 500px;
}
.npd-leaderboard-table th {
  background: var(--npd-navy);
  color: var(--npd-white);
  padding: 1rem 1.25rem;
  text-align: left;
  font-size: 0.85rem;
  letter-spacing: 1px;
  text-transform: uppercase;
}
.npd-leaderboard-table td {
  padding: 0.9rem 1.25rem;
  border-bottom: 1px solid var(--npd-grey);
  font-size: 0.95rem;
}
.npd-leaderboard-table tr:last-child td { border-bottom: none; }
.npd-leaderboard-table tr:hover td { background: var(--npd-grey-lt); }
.npd-rank-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px; height: 28px;
  border-radius: 50%;
  font-weight: 800;
  font-size: 0.85rem;
}
.npd-rank-badge--1 { background: #ffd700; color: #6b4400; }
.npd-rank-badge--2 { background: #c0c0c0; color: #3d3d3d; }
.npd-rank-badge--3 { background: #cd7f32; color: var(--npd-white); }
.npd-rank-badge--n { background: var(--npd-grey); color: var(--npd-text); }
.npd-points-tag {
  background: rgba(78,205,196,0.12);
  color: var(--npd-cyan);
  border-radius: 99px;
  padding: 0.2rem 0.7rem;
  font-weight: 700;
  font-size: 0.88rem;
}

/* ========== PLAY-ONLINE PAGE ========== */
.npd-play-header {
  background: linear-gradient(135deg, var(--npd-navy) 0%, var(--npd-blue) 100%);
  padding: 7rem 0 4rem;
  text-align: center;
  color: var(--npd-white);
}
.npd-play-header h1 { color: var(--npd-white); margin-bottom: 0.75rem; }
.npd-play-header p  { color: rgba(255,255,255,0.7); font-size: 1.1rem; }
.npd-play-disclaimer {
  background: rgba(78,205,196,0.12);
  border: 1.5px solid var(--npd-cyan);
  border-radius: var(--npd-radius);
  padding: 1rem 1.5rem;
  color: var(--npd-white);
  font-size: 0.9rem;
  font-weight: 600;
  text-align: center;
  max-width: 700px;
  margin: 1.5rem auto 0;
}

.npd-deck-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.75rem;
  margin-bottom: 3rem;
}
.npd-deck-card {
  background: var(--npd-white);
  border-radius: var(--npd-radius-lg);
  padding: 2rem;
  box-shadow: var(--npd-shadow);
  cursor: pointer;
  border: 3px solid transparent;
  transition: border-color var(--npd-transition), transform var(--npd-transition), box-shadow var(--npd-transition);
  text-align: center;
}
.npd-deck-card:hover {
  border-color: var(--npd-violet);
  transform: translateY(-4px);
  box-shadow: var(--npd-shadow-lg);
}
.npd-deck-card.selected {
  border-color: var(--npd-cyan);
  background: linear-gradient(135deg, rgba(78,205,196,0.05) 0%, rgba(107,79,160,0.05) 100%);
}
.npd-deck-card__icon { font-size: 3.5rem; margin-bottom: 0.75rem; }
.npd-deck-card__title { font-size: 1.05rem; font-weight: 700; margin-bottom: 0.4rem; color: var(--npd-navy); }
.npd-deck-card__desc  { font-size: 0.85rem; color: var(--npd-text-lt); }

@media (max-width: 768px) {
  .npd-deck-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 480px) {
  .npd-deck-grid { grid-template-columns: 1fr; }
}

.npd-play-panel {
  background: linear-gradient(135deg, var(--npd-navy) 0%, var(--npd-blue) 50%, #1e1040 100%);
  border-radius: var(--npd-radius-lg);
  box-shadow: 0 12px 48px rgba(10,14,26,0.4), 0 0 60px rgba(107,79,160,0.3);
  padding: 2.5rem;
  max-width: 640px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.npd-play-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse 60% 50% at 80% 50%, rgba(107,79,160,0.2) 0%, transparent 60%),
              radial-gradient(ellipse 40% 40% at 20% 80%, rgba(78,205,196,0.1) 0%, transparent 50%);
  pointer-events: none;
}
.npd-play-panel h3 { margin-bottom: 1.5rem; color: var(--npd-white); position: relative; z-index: 1; }
.npd-play-btn {
  background: linear-gradient(135deg, var(--npd-cyan) 0%, var(--npd-cyan-lt) 100%);
  color: var(--npd-navy);
  border: none;
  border-radius: var(--npd-radius);
  padding: 1rem 2.5rem;
  font-size: 1.05rem;
  font-weight: 700;
  cursor: pointer;
  transition: var(--npd-transition);
  margin-bottom: 1.5rem;
  position: relative;
  z-index: 2;
  box-shadow: 0 8px 24px rgba(78,205,196,0.3);
}
.npd-play-btn:hover:not(:disabled) {
  background: linear-gradient(135deg, var(--npd-cyan-lt) 0%, var(--npd-cyan) 100%);
  transform: translateY(-3px);
  box-shadow: 0 12px 32px rgba(78,205,196,0.5);
}
.npd-play-btn:disabled { opacity: 0.6; cursor: not-allowed; }
.npd-play-result {
  background: rgba(26,37,71,0.5);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(78,205,196,0.2);
  border-radius: var(--npd-radius);
  padding: 1.5rem;
  display: none;
  animation: npd-fade-in 0.4s ease;
  position: relative;
  z-index: 2;
}
.npd-play-result.visible { display: block; }
.npd-play-result__symbols {
  font-size: 3rem;
  letter-spacing: 0.25em;
  margin-bottom: 0.75rem;
}
.npd-play-result__outcome {
  font-size: 1.25rem;
  font-weight: 800;
  color: var(--npd-cyan-lt);
  margin-bottom: 0.5rem;
}
.npd-play-result__points {
  font-size: 0.95rem;
  color: rgba(255,255,255,0.7);
}
.npd-play-disclaimer-inline {
  margin-top: 1.25rem;
  font-size: 0.82rem;
  color: var(--npd-text-lt);
  border-top: 1px solid var(--npd-grey);
  padding-top: 1rem;
}

/* Game Grid 3x3 */
.npd-game-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.6rem;
  margin: 1.5rem auto;
  padding: 1.2rem;
  background: rgba(26,37,71,0.4);
  border-radius: var(--npd-radius);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(78,205,196,0.2);
  position: relative;
  z-index: 2;
  width: fit-content;
}

.npd-game-cell {
  aspect-ratio: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, rgba(78,205,196,0.15) 0%, rgba(107,79,160,0.1) 100%);
  border: 2px solid rgba(78,205,196,0.4);
  border-radius: var(--npd-radius);
  font-size: 1.8rem;
  cursor: pointer;
  transition: all var(--npd-transition);
  font-weight: 700;
  min-height: 60px;
  color: var(--npd-white);
  box-shadow: 0 4px 12px rgba(78,205,196,0.1);
}

.npd-game-cell:hover {
  border-color: var(--npd-cyan);
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(78,205,196,0.25), 0 0 20px rgba(78,205,196,0.15);
  background: linear-gradient(135deg, rgba(78,205,196,0.3) 0%, rgba(107,79,160,0.2) 100%);
}

.npd-game-cell.matched {
  background: linear-gradient(135deg, rgba(78,205,196,0.4) 0%, rgba(107,79,160,0.35) 100%);
  border-color: var(--npd-cyan-lt);
  box-shadow: 0 8px 24px rgba(78,205,196,0.4), 0 0 30px rgba(78,205,196,0.2);
  animation: npd-pulse-match 0.5s ease;
}

@keyframes npd-pulse-match {
  0% { transform: scale(1); }
  50% { transform: scale(1.1); }
  100% { transform: scale(1); }
}

/* Large variants */
.npd-play-panel--large {
  max-width: 900px;
  padding: 3rem;
  background: linear-gradient(135deg, var(--npd-navy) 0%, var(--npd-blue) 50%, #1e1040 100%);
}

.npd-play-btn--large {
  padding: 1.25rem 3.5rem;
  font-size: 1.25rem;
  width: 100%;
  margin-top: 1.5rem;
  background: linear-gradient(135deg, var(--npd-cyan) 0%, var(--npd-cyan-lt) 100%);
  color: var(--npd-navy);
  box-shadow: 0 8px 24px rgba(78,205,196,0.3);
  font-weight: 800;
  letter-spacing: 0.5px;
}

.npd-play-btn--large:hover:not(:disabled) {
  transform: translateY(-4px);
  box-shadow: 0 16px 48px rgba(78,205,196,0.5);
  background: linear-gradient(135deg, var(--npd-cyan-lt) 0%, var(--npd-cyan) 100%);
}

.npd-game-controls {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1rem;
  position: relative;
  z-index: 2;
}

.npd-score-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: var(--npd-cyan-lt);
  font-weight: 700;
}

.npd-score-label {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: rgba(255,255,255,0.6);
  margin-bottom: 0.25rem;
}

.npd-score-value {
  font-size: 1.8rem;
}

.npd-control-btn {
  background: linear-gradient(135deg, rgba(78,205,196,0.3) 0%, rgba(78,205,196,0.2) 100%);
  color: var(--npd-cyan-lt);
  border: 1px solid rgba(78,205,196,0.4);
  border-radius: var(--npd-radius);
  padding: 0.6rem 1rem;
  font-size: 0.85rem;
  cursor: pointer;
  transition: all var(--npd-transition);
  font-weight: 600;
}

.npd-control-btn:hover {
  background: linear-gradient(135deg, rgba(78,205,196,0.5) 0%, rgba(78,205,196,0.3) 100%);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(78,205,196,0.2);
}

.npd-result-btn {
  background: linear-gradient(135deg, var(--npd-violet) 0%, var(--npd-violet-lt) 100%);
  color: var(--npd-white);
  border: none;
  border-radius: var(--npd-radius);
  padding: 1rem 2rem;
  font-size: 1rem;
  cursor: pointer;
  transition: all var(--npd-transition);
  font-weight: 700;
  display: inline-block;
  text-decoration: none;
}

.npd-result-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(107,79,160,0.4);
  background: linear-gradient(135deg, var(--npd-violet-lt) 0%, var(--npd-violet) 100%);
}

@media (max-width: 768px) {
  .npd-container {
    padding: 0 1rem;
  }
  .npd-section {
    padding: 3rem 0;
  }
  .npd-game-grid {
    gap: 0.5rem;
    padding: 1rem;
  }
  .npd-game-cell {
    font-size: 1.4rem;
    min-height: 50px;
  }
  .npd-play-panel--large {
    padding: 1.5rem;
  }
  .npd-play-btn--large {
    padding: 0.9rem 2rem;
    font-size: 1rem;
  }
  .npd-score-value {
    font-size: 1.5rem;
  }
  .npd-game-controls {
    gap: 0.5rem;
  }
}

@media (max-width: 480px) {
  html { font-size: 15px; }
  
  .npd-container {
    padding: 0 0.75rem;
  }
  .npd-section {
    padding: 2rem 0;
  }
  .npd-game-grid {
    gap: 0.4rem;
    padding: 0.8rem;
  }
  .npd-game-cell {
    font-size: 1.2rem;
    min-height: 45px;
  }
  .npd-play-btn--large {
    padding: 0.8rem 1.5rem;
    font-size: 1rem;
    margin-bottom: 1rem;
  }
  .npd-play-panel--large {
    padding: 1rem;
  }
  .npd-game-controls {
    flex-wrap: wrap;
    gap: 0.3rem;
    margin-bottom: 1rem;
  }
  .npd-control-btn {
    padding: 0.5rem 0.6rem !important;
    font-size: 0.75rem !important;
    flex: 1;
    min-width: 70px;
  }
  .npd-score-label {
    font-size: 0.65rem !important;
  }
  .npd-score-value {
    font-size: 1.3rem !important;
  }
  .npd-play-header h1 {
    font-size: 1.8rem;
  }
  .npd-play-header p {
    font-size: 0.95rem;
  }
}

/* Progress & Credits display */
.npd-progress-stat { color: var(--npd-white); }
.npd-progress-stat__num { font-size: 2rem; font-weight: 900; color: var(--npd-cyan); }
.npd-progress-stat__label { font-size: 0.8rem; color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 1px; margin-top: 0.25rem; }

.npd-earned-badge {
  background: rgba(107,79,160,0.15);
  border: 2px solid var(--npd-violet);
  border-radius: 99px;
  padding: 0.4rem 1rem;
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--npd-violet);
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

@media (max-width: 480px) {
  .npd-play-panel { padding: 1.5rem; }
}

@keyframes npd-fade-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ========== CONTENT PAGES ========== */
.npd-page-hero {
  background: linear-gradient(135deg, var(--npd-navy) 0%, var(--npd-blue) 100%);
  padding: 7rem 0 4rem;
  text-align: center;
}
.npd-page-hero h1 { color: var(--npd-white); margin-bottom: 0.5rem; }
.npd-page-hero p  { color: rgba(255,255,255,0.65); font-size: 1.1rem; margin: 0; }

.npd-content-body {
  max-width: 820px;
  margin: 0 auto;
}
.npd-content-body h2 {
  margin-top: 2.5rem;
  margin-bottom: 0.75rem;
  padding-top: 0.5rem;
  border-top: 2px solid var(--npd-grey);
  font-size: 1.4rem;
}
.npd-content-body h3 { margin-top: 1.75rem; margin-bottom: 0.5rem; font-size: 1.15rem; }
.npd-content-body p  { font-size: 0.97rem; color: var(--npd-text); }
.npd-content-body ul { list-style: disc; padding-left: 1.5rem; display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 1rem; }
.npd-content-body li { font-size: 0.97rem; color: var(--npd-text); }

/* ========== CONTACT FORM ========== */
.npd-contact-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}
.npd-form { display: flex; flex-direction: column; gap: 1.25rem; }
.npd-form-group label {
  display: block;
  font-size: 0.88rem;
  font-weight: 700;
  margin-bottom: 0.4rem;
  color: var(--npd-navy);
}
.npd-form-group input,
.npd-form-group textarea,
.npd-form-group select {
  width: 100%;
  padding: 0.85rem 1rem;
  border: 2px solid var(--npd-grey);
  border-radius: var(--npd-radius);
  font-size: 0.97rem;
  color: var(--npd-text);
  background: var(--npd-white);
  transition: border-color var(--npd-transition);
  outline: none;
  font-family: inherit;
}
.npd-form-group input:focus,
.npd-form-group textarea:focus,
.npd-form-group select:focus {
  border-color: var(--npd-violet);
  box-shadow: 0 0 0 3px rgba(107,79,160,0.12);
}
.npd-form-group textarea { resize: vertical; min-height: 140px; }
.npd-form-note {
  background: var(--npd-grey-lt);
  border-radius: var(--npd-radius);
  padding: 1.25rem;
  font-size: 0.88rem;
  color: var(--npd-text-lt);
}
.npd-form-note strong { color: var(--npd-navy); }
.npd-contact-info { display: flex; flex-direction: column; gap: 1.5rem; }
.npd-contact-card {
  background: var(--npd-grey-lt);
  border-radius: var(--npd-radius);
  padding: 1.5rem;
  display: flex;
  gap: 1rem;
  align-items: flex-start;
}
.npd-contact-card__icon { font-size: 1.75rem; }
.npd-contact-card h4 { margin-bottom: 0.25rem; font-size: 0.97rem; }
.npd-contact-card p  { font-size: 0.88rem; color: var(--npd-text-lt); margin: 0; }

@media (max-width: 768px) {
  .npd-contact-grid { grid-template-columns: 1fr; gap: 2.5rem; }
}

/* ========== FOOTER ========== */
.npd-footer {
  background: var(--npd-navy);
  color: var(--npd-white);
  padding: 4rem 0 0;
}
.npd-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 3rem;
  margin-bottom: 3rem;
}
.npd-footer__brand p {
  color: rgba(255,255,255,0.6);
  font-size: 0.9rem;
  margin: 0.75rem 0 1.5rem;
  line-height: 1.7;
}
.npd-footer__logo {
  font-family: 'Syne', 'Oswald', sans-serif;
  font-size: 1.3rem;
  font-weight: 800;
  color: var(--npd-white);
  letter-spacing: -0.5px;
  text-decoration: none;
}
.npd-footer__logo span { color: var(--npd-cyan); }
.npd-footer__col-title {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--npd-cyan);
  margin-bottom: 1.25rem;
}
.npd-footer__links { display: flex; flex-direction: column; gap: 0.6rem; }
.npd-footer__links a {
  color: rgba(255,255,255,0.65);
  font-size: 0.9rem;
  transition: color var(--npd-transition);
  text-decoration: none;
}
.npd-footer__links a:hover { color: var(--npd-white); }
.npd-footer__bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: 1.5rem 0;
}
.npd-footer__bottom-inner {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.npd-footer__disclaimer {
  background: rgba(255,255,255,0.05);
  border-radius: var(--npd-radius);
  padding: 1.25rem 1.5rem;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.5);
  line-height: 1.65;
}
.npd-footer__disclaimer strong { color: rgba(255,255,255,0.8); }
.npd-footer__copy {
  font-size: 0.82rem;
  color: rgba(255,255,255,0.4);
  display: flex;
  gap: 1.5rem;
  flex-wrap: wrap;
  align-items: center;
}
.npd-footer__copy a { color: rgba(255,255,255,0.55); }
.npd-footer__copy a:hover { color: var(--npd-white); }
.npd-18-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--npd-coral);
  color: var(--npd-white);
  font-weight: 900;
  font-size: 0.75rem;
  border-radius: 6px;
  padding: 0.2rem 0.55rem;
  margin-left: 0.25rem;
}

@media (max-width: 900px) {
  .npd-footer__grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}
@media (max-width: 560px) {
  .npd-footer__grid { grid-template-columns: 1fr; }
}

/* ========== TRUST STRIP ========== */
.npd-trust-strip {
  background: var(--npd-dark-blue);
  padding: 1.25rem 0;
  border-top: 1px solid rgba(255,255,255,0.07);
}
.npd-trust-strip__inner {
  display: flex;
  align-items: center;
  gap: 2rem;
  flex-wrap: wrap;
  justify-content: center;
}
.npd-trust-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.82rem;
  color: rgba(255,255,255,0.55);
  white-space: nowrap;
}
.npd-trust-item svg, .npd-trust-item span.icon { color: var(--npd-cyan); }

/* ========== SUCCESS / FORM ========== */
.npd-success-box {
  background: rgba(78,205,196,0.1);
  border: 2px solid var(--npd-cyan);
  border-radius: var(--npd-radius);
  padding: 1.5rem;
  text-align: center;
  display: none;
}
.npd-success-box.visible { display: block; }
.npd-success-box p { margin: 0; color: var(--npd-navy); font-weight: 600; }

/* ========== PLAY ONLINE EXTRAS ========== */

/* Progress section wrapper override */
.npd-progress-section {
  background: var(--npd-navy);
  padding: 2rem 0;
  margin-bottom: 0;
  display: block;
}
.npd-progress-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  text-align: center;
  margin-bottom: 1.5rem;
}
.npd-progress-stat__value {
  font-size: 2rem;
  font-weight: 900;
  color: var(--npd-cyan);
}

/* Earned badges nested layout */
.npd-earned-badges {
  background: rgba(107,79,160,0.12);
  border: 1px solid rgba(107,79,160,0.3);
  border-radius: var(--npd-radius);
  padding: 1rem 1.25rem;
  margin-top: 1rem;
}
.npd-earned-badges__label {
  font-size: 0.8rem;
  font-weight: 700;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 0.75rem;
}
.npd-earned-badges__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

/* Play step indicator */
.npd-play-step {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1.5rem;
  font-weight: 700;
  color: var(--npd-navy);
  font-size: 1.05rem;
}
.npd-play-step__num {
  width: 2rem;
  height: 2rem;
  border-radius: 50%;
  background: var(--npd-violet);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 800;
  flex-shrink: 0;
}

/* Deck card extras */
.npd-deck-card__name { font-size: 1.05rem; font-weight: 700; margin-bottom: 0.4rem; color: var(--npd-navy); }
.npd-deck-card__symbols { font-size: 1.3rem; margin: 0.75rem 0 0.5rem; letter-spacing: 0.15rem; }
.npd-deck-card__select-tag {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--npd-violet);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 0.5rem;
  transition: color 0.2s;
}
.npd-deck-card.selected .npd-deck-card__select-tag { color: var(--npd-cyan); }
.npd-deck-card__glow {
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: radial-gradient(circle at center, rgba(107,79,160,0.15) 0%, transparent 70%);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.3s;
}
.npd-deck-card:hover .npd-deck-card__glow,
.npd-deck-card.selected .npd-deck-card__glow { opacity: 1; }
.npd-deck-card { position: relative; }

/* Play button text/hint spans */
.npd-play-btn__text { display: block; }
.npd-play-btn__hint { display: block; font-size: 0.8rem; opacity: 0.7; font-weight: 400; margin-top: 0.25rem; }
.npd-play-btn:not(:disabled) .npd-play-btn__hint { display: none; }

@media (max-width: 600px) {
  .npd-progress-stats { grid-template-columns: repeat(3, 1fr); gap: 0.75rem; }
  .npd-progress-stat__value { font-size: 1.5rem; }
}

@media (max-width: 480px) {
  .npd-progress-stats { grid-template-columns: 1fr; gap: 1rem; }
  .npd-progress-stat__value { font-size: 1.8rem; }
}

/* ========== UTILITIES ========== */
.text-center { text-align: center; }
.text-white  { color: var(--npd-white) !important; }
.mt-1 { margin-top: 0.5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mt-4 { margin-top: 2rem; }
.mb-1 { margin-bottom: 0.5rem; }
.mb-2 { margin-bottom: 1rem; }
.mb-3 { margin-bottom: 1.5rem; }
.mb-4 { margin-bottom: 2rem; }
