/* ── Night Kitchen Public: shared dark theme for all marketing pages ── */
/* Reusable .nkp-* classes generalized from the page-specific .fa-* set */
/* Buttons (.btn, .btn-on-dark, .btn-outline-dark, .btn-lg) live in     */
/* landing.css — do NOT redefine them here.                          */

/* ── 1. Wrapper ─────────────────────────────────────────────────────── */
.nkp {
  background: #0b0f0c;
  color: var(--cream);
  font-family: var(--sans);
}

/* ── 2. Dark nav override (landing .va + marketing .nkp pages) ──────── */
/* Nav background is transparent — backdrop-filter in landing.css provides
   the frosted-glass effect over the dark hero. No explicit background. */
.pub.va .nav,
.pub:has(.nkp) .nav {
  background: transparent;
  border-bottom: none;
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
}
.pub.va .logo,
.pub:has(.nkp) .logo { color: var(--cream); }
.pub.va .logo-mark,
.pub:has(.nkp) .logo-mark { background: var(--cream); color: var(--ink); }
.pub.va .nav-links a,
.pub:has(.nkp) .nav-links a { color: rgba(246,241,228,0.75); }
.pub.va .nav-links a:hover,
.pub:has(.nkp) .nav-links a:hover { color: var(--cream); }
.pub.va .nav-cta a:first-child,
.pub:has(.nkp) .nav-cta a:first-child { color: rgba(246,241,228,0.7) !important; }
.pub.va .nav-cta .btn-primary,
.pub:has(.nkp) .nav-cta .btn-primary { background: var(--cream); color: var(--ink); }
.pub.va .nav-cta .btn-primary:hover,
.pub:has(.nkp) .nav-cta .btn-primary:hover { background: #fff; }
.pub.va .nav-burger svg,
.pub:has(.nkp) .nav-burger svg { stroke: var(--cream); }

/* ── 3. Hero ─────────────────────────────────────────────────────────── */
.nkp-hero {
  padding: 80px 0 100px;
  border-bottom: 1px solid rgba(246,241,228,0.08);
}
.nkp-hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 72px;
  align-items: center;
}
@media (max-width: 900px) {
  .nkp-hero-grid { grid-template-columns: 1fr; gap: 48px; }
}
.nkp-kicker {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.12em;
  color: rgba(246,241,228,0.6); text-transform: uppercase;
  padding: 7px 14px; border: 1px solid rgba(246,241,228,0.18); border-radius: 999px;
  margin-bottom: 28px;
}
.nkp-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: #e9c88b;
  box-shadow: 0 0 0 4px rgba(233,200,139,0.18);
}
.nkp-h1 {
  font-size: clamp(42px, 4.8vw, 72px);
  line-height: 1.04;
  letter-spacing: -0.03em;
  font-weight: 700;
  max-width: 16ch;
}
.nkp-h1 .serif {
  font-family: var(--serif); font-style: italic; font-weight: 400;
  color: #e9c88b; display: inline;
}
.nkp-sub {
  margin-top: 28px;
  font-size: 18px;
  color: rgba(246,241,228,0.68);
  max-width: 48ch;
  line-height: 1.55;
}
.nkp-cta-row { margin-top: 36px; display: flex; flex-wrap: wrap; gap: 12px; align-items: center; }
.nkp-fine {
  margin-top: 18px; font-family: var(--mono); font-size: 12px;
  color: rgba(246,241,228,0.42); letter-spacing: 0.02em;
}
.nkp-fine a {
  color: #e9c88b; text-decoration: underline;
  text-underline-offset: 3px; text-decoration-color: rgba(233,200,139,0.4);
}
.nkp-fine a:hover { text-decoration-color: #e9c88b; }

/* ── 4. Preview card (cream on dark) ─────────────────────────────────── */
.nkp-preview {
  background: var(--cream); color: var(--ink);
  border-radius: 14px;
  padding: 32px;
  position: relative;
  box-shadow: 0 40px 80px -30px rgba(0,0,0,0.6), 0 8px 20px -10px rgba(0,0,0,0.4);
}
.nkp-preview-badge {
  position: absolute; top: 14px; right: 14px;
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.14em;
  text-transform: uppercase; color: rgba(11,15,12,0.4);
}
.nkp-preview-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 24px;
  padding-bottom: 16px; border-bottom: 1px solid rgba(11,15,12,0.08);
}
.nkp-preview-icon {
  width: 32px; height: 32px; border-radius: 8px;
  background: rgba(233,200,139,0.15); border: 1px solid rgba(233,200,139,0.3);
  display: grid; place-items: center; font-family: var(--serif); font-style: italic;
  font-size: 16px; color: #a67c00;
}
.nkp-preview-title { font-weight: 600; font-size: 14px; }
.nkp-preview-free {
  margin-left: auto; font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--accent); background: rgba(4,120,87,0.08);
  padding: 4px 10px; border-radius: 4px; border: 1px solid rgba(4,120,87,0.15);
}
.nkp-preview-row {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 0; border-bottom: 1px solid rgba(11,15,12,0.06);
}
.nkp-preview-row:last-child { border-bottom: 0; }
.nkp-preview-label { font-size: 13.5px; color: rgba(11,15,12,0.55); }
.nkp-preview-val { font-size: 28px; font-weight: 700; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.nkp-preview-val.emerald { color: var(--accent); }
.nkp-preview-val.gold { color: #a67c00; }
.nkp-preview-val.blue { color: #1d4ed8; }

/* ── 5. Section basics ───────────────────────────────────────────────── */
.nkp-section {
  padding: 100px 0;
  border-bottom: 1px solid rgba(246,241,228,0.08);
}
.nkp-eyebrow {
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.2em;
  text-transform: uppercase; color: rgba(246,241,228,0.5); margin-bottom: 20px;
}
.nkp-h2 {
  font-size: clamp(36px, 4vw, 56px);
  line-height: 1.06; letter-spacing: -0.03em; font-weight: 700;
  max-width: 20ch;
}
.nkp-h2 .serif { font-family: var(--serif); font-style: italic; font-weight: 400; color: #e9c88b; }

/* ── 6. Stat grid ────────────────────────────────────────────────────── */
.nkp-stat-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 2px; margin-top: 48px;
  background: rgba(246,241,228,0.08);
  border: 1px solid rgba(246,241,228,0.08);
  border-radius: 8px; overflow: hidden;
}
@media (max-width: 700px) { .nkp-stat-grid { grid-template-columns: 1fr; } }
.nkp-stat {
  background: #0b0f0c; padding: 40px 32px;
}
.nkp-stat .num {
  font-size: 48px; letter-spacing: -0.03em; line-height: 1; font-weight: 700;
  color: #ef4444;
}
.nkp-stat .num.gold { color: #e9c88b; }
.nkp-stat .lbl {
  font-size: 14px; color: rgba(246,241,228,0.6); margin-top: 10px; max-width: 24ch;
}

/* ── 7. Steps ────────────────────────────────────────────────────────── */
.nkp-steps { margin-top: 56px; }
.nkp-step {
  display: grid; grid-template-columns: 72px 1fr 1.2fr; gap: 40px;
  padding: 32px 0; border-top: 1px solid rgba(246,241,228,0.1);
  align-items: start;
}
.nkp-step:last-child { border-bottom: 1px solid rgba(246,241,228,0.1); }
.nkp-step-num {
  font-family: var(--serif); font-style: italic;
  font-size: 48px; line-height: 0.9; color: #e9c88b;
}
.nkp-step-title { font-size: 22px; letter-spacing: -0.02em; font-weight: 600; }
.nkp-step-desc { font-size: 15px; color: rgba(246,241,228,0.68); line-height: 1.55; max-width: 48ch; }
@media (max-width: 760px) {
  .nkp-step { grid-template-columns: 56px 1fr; }
  .nkp-step-desc { grid-column: 1 / -1; }
}

/* ── 8. Benefit grid ─────────────────────────────────────────────────── */
.nkp-benefit-grid {
  display: grid; grid-template-columns: repeat(2, 1fr);
  gap: 2px; margin-top: 48px;
  background: rgba(246,241,228,0.06);
  border: 1px solid rgba(246,241,228,0.08);
  border-radius: 8px; overflow: hidden;
}
@media (max-width: 700px) { .nkp-benefit-grid { grid-template-columns: 1fr; } }
.nkp-benefit {
  background: #0b0f0c; padding: 36px 32px;
}
.nkp-benefit-icon {
  width: 36px; height: 36px; border-radius: 8px; margin-bottom: 16px;
  display: grid; place-items: center;
  background: rgba(246,241,228,0.06); border: 1px solid rgba(246,241,228,0.1);
}
.nkp-benefit-icon svg { width: 18px; height: 18px; stroke: #e9c88b; fill: none; stroke-width: 1.8; }
.nkp-benefit-title { font-size: 17px; font-weight: 600; margin-bottom: 8px; letter-spacing: -0.01em; }
.nkp-benefit-desc { font-size: 14px; color: rgba(246,241,228,0.6); line-height: 1.55; max-width: 36ch; }

/* ── 9. Comparison panel ─────────────────────────────────────────────── */
.nkp-compare {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 0; margin-top: 48px;
  border: 1px solid rgba(246,241,228,0.1);
  border-radius: 8px; overflow: hidden;
}
@media (max-width: 700px) { .nkp-compare { grid-template-columns: 1fr; } }
.nkp-compare-left { background: #0b0f0c; padding: 48px 40px; }
.nkp-compare-right { background: var(--cream); color: var(--ink); padding: 48px 40px; }
.nkp-compare-h {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.14em;
  text-transform: uppercase; margin-bottom: 24px; font-weight: 600;
}
.nkp-compare-left .nkp-compare-h { color: #ef4444; }
.nkp-compare-right .nkp-compare-h { color: var(--accent); }
.nkp-compare-item {
  display: flex; align-items: start; gap: 12px;
  padding: 10px 0; font-size: 14.5px; line-height: 1.5;
}
.nkp-compare-left .nkp-compare-item { color: rgba(246,241,228,0.72); }
.nkp-compare-right .nkp-compare-item { color: rgba(11,15,12,0.7); }
.nkp-compare-item strong { color: var(--cream); font-weight: 600; }
.nkp-compare-right .nkp-compare-item strong { color: var(--ink); }
.nkp-compare-icon { flex-shrink: 0; margin-top: 3px; }
.nkp-compare-icon.bad { color: #ef4444; }
.nkp-compare-icon.good { color: var(--accent); }
.nkp-compare-footer {
  grid-column: 1 / -1;
  background: rgba(246,241,228,0.04);
  border-top: 1px solid rgba(246,241,228,0.08);
  padding: 20px 40px;
  text-align: center;
  font-size: 14px; color: rgba(246,241,228,0.6);
}
.nkp-compare-footer strong { color: var(--accent-2); font-size: 20px; font-weight: 700; }

/* ── 10. Integration badges ──────────────────────────────────────────── */
.nkp-integrations {
  padding: 72px 0;
  border-bottom: 1px solid rgba(246,241,228,0.08);
  text-align: center;
}
.nkp-integrations h3 {
  font-size: 16px; color: rgba(246,241,228,0.7); font-weight: 500; margin-bottom: 28px;
}
.nkp-badge-row { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; }
.nkp-badge {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.06em;
  padding: 8px 16px; border-radius: 6px;
  border: 1px solid rgba(246,241,228,0.12);
  color: rgba(246,241,228,0.7);
  background: rgba(246,241,228,0.04);
}
.nkp-badge.active { border-color: rgba(16,185,129,0.3); color: var(--accent-2); background: rgba(16,185,129,0.06); }

/* ── 11. Support timeline ────────────────────────────────────────────── */
.nkp-support {
  padding: 100px 0;
  border-bottom: 1px solid rgba(246,241,228,0.08);
}
.nkp-support-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 2px; margin-top: 48px;
  background: rgba(246,241,228,0.06);
  border: 1px solid rgba(246,241,228,0.08);
  border-radius: 8px; overflow: hidden;
}
@media (max-width: 900px) { .nkp-support-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .nkp-support-grid { grid-template-columns: 1fr; } }
.nkp-support-step {
  background: #0b0f0c; padding: 32px 24px; text-align: center;
}
.nkp-support-time {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em;
  text-transform: uppercase; color: rgba(246,241,228,0.4); margin-bottom: 12px;
}
.nkp-support-icon {
  width: 44px; height: 44px; border-radius: 50%; margin: 0 auto 14px;
  display: grid; place-items: center;
}
.nkp-support-icon.red { background: rgba(239,68,68,0.12); border: 1px solid rgba(239,68,68,0.25); }
.nkp-support-icon.amber { background: rgba(245,158,11,0.12); border: 1px solid rgba(245,158,11,0.25); }
.nkp-support-icon.blue { background: rgba(59,130,246,0.12); border: 1px solid rgba(59,130,246,0.25); }
.nkp-support-icon.emerald { background: rgba(16,185,129,0.12); border: 1px solid rgba(16,185,129,0.25); }
.nkp-support-icon svg { width: 20px; height: 20px; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.nkp-support-icon.red svg { stroke: #ef4444; }
.nkp-support-icon.amber svg { stroke: #f59e0b; }
.nkp-support-icon.blue svg { stroke: #3b82f6; }
.nkp-support-icon.emerald svg { stroke: #10b981; }
.nkp-support-title { font-size: 14px; font-weight: 600; margin-bottom: 6px; }
.nkp-support-desc { font-size: 12.5px; color: rgba(246,241,228,0.55); line-height: 1.5; }

/* ── 12. FAQ ─────────────────────────────────────────────────────────── */
.nkp-faq {
  padding: 100px 0;
  border-bottom: 1px solid rgba(246,241,228,0.08);
}
.nkp-faq details {
  border-top: 1px solid rgba(246,241,228,0.12);
  padding: 22px 0;
}
.nkp-faq details:last-child { border-bottom: 1px solid rgba(246,241,228,0.12); }
.nkp-faq summary {
  list-style: none; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center; gap: 24px;
  font-size: 18px; font-weight: 500; letter-spacing: -0.01em;
}
.nkp-faq summary::-webkit-details-marker { display: none; }
.nkp-faq summary .plus {
  font-family: var(--serif); font-style: italic; color: #e9c88b;
  font-size: 26px; transition: transform .25s ease; flex-shrink: 0;
}
.nkp-faq details[open] summary .plus { transform: rotate(45deg); }
.nkp-faq .answer {
  margin-top: 14px; font-size: 15px; color: rgba(246,241,228,0.68);
  max-width: 64ch; line-height: 1.6;
}

/* ── 13. Final CTA ───────────────────────────────────────────────────── */
.nkp-final {
  padding: 120px 0 140px;
  background:
    radial-gradient(800px 400px at 30% 100%, rgba(233,200,139,0.1), transparent 70%),
    #0b0f0c;
}
.nkp-final-h {
  font-size: clamp(48px, 6vw, 88px);
  letter-spacing: -0.035em; line-height: 0.98;
  font-weight: 700; max-width: 14ch;
}
.nkp-final-h .serif { font-family: var(--serif); font-style: italic; font-weight: 400; color: #e9c88b; }
.nkp-final-sub {
  margin-top: 24px; font-size: 17px; color: rgba(246,241,228,0.65);
  max-width: 48ch; line-height: 1.55;
}
.nkp-final-cta { margin-top: 40px; display: flex; flex-wrap: wrap; gap: 12px; }
.nkp-final-fine {
  margin-top: 20px; font-family: var(--mono); font-size: 12px;
  color: rgba(246,241,228,0.4); letter-spacing: 0.02em;
}

/* ── 14. Pricing card ────────────────────────────────────────────────── */
.nkp-price {
  display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
  gap: 0;
  background: #0b0f0c;
  border: 1px solid rgba(246,241,228,0.1);
  border-radius: 8px;
  overflow: hidden;
  margin-top: 48px;
}
@media (max-width: 900px) { .nkp-price { grid-template-columns: 1fr; } }
.nkp-price-left { padding: 56px 48px; }
.nkp-price-right { padding: 56px 48px; background: var(--cream); color: var(--ink); }
.nkp-price .big {
  font-family: var(--serif); font-style: italic;
  font-size: 200px; line-height: 0.88; letter-spacing: -0.04em;
  color: #e9c88b;
}
.nkp-price .big .currency {
  font-size: 100px; vertical-align: top; margin-right: 4px;
  font-style: normal; font-family: var(--sans); font-weight: 500;
  letter-spacing: -0.02em; color: rgba(246,241,228,0.85);
}
.nkp-price .per {
  font-family: var(--mono); font-size: 13px; letter-spacing: 0.12em;
  text-transform: uppercase; color: rgba(246,241,228,0.55); margin-top: 14px;
}
.nkp-price .cap {
  margin-top: 18px; font-size: 15px; color: rgba(246,241,228,0.7); max-width: 34ch;
}
.nkp-price-right h3 {
  font-size: 14px; font-family: var(--mono); letter-spacing: 0.14em;
  text-transform: uppercase; color: #847a5c; margin-bottom: 18px; font-weight: 600;
}
.nkp-feature {
  display: flex; gap: 12px; padding: 10px 0; font-size: 15px;
  border-top: 1px solid rgba(11,15,12,0.08);
}
.nkp-feature:first-of-type { border-top: 0; }
.nkp-feature .chk { color: var(--accent); flex-shrink: 0; margin-top: 2px; }

/* ── 15. Pain points list ────────────────────────────────────────────── */
.nkp-pain-list {
  margin-top: 48px;
  display: flex; flex-direction: column; gap: 2px;
}
.nkp-pain {
  display: flex; align-items: start; gap: 16px;
  background: rgba(246,241,228,0.03);
  border: 1px solid rgba(246,241,228,0.1);
  border-radius: 8px;
  padding: 20px 24px;
  font-size: 15px; line-height: 1.5;
  color: rgba(246,241,228,0.72);
}
.nkp-pain-icon {
  flex-shrink: 0; margin-top: 2px; color: #ef4444;
}
.nkp-solution {
  margin-top: 24px;
  padding: 20px 24px;
  background: rgba(16,185,129,0.06);
  border: 1px solid rgba(16,185,129,0.2);
  border-radius: 8px;
  font-size: 15px; line-height: 1.5;
  color: rgba(246,241,228,0.8);
  display: flex; align-items: start; gap: 16px;
}
.nkp-solution .nkp-pain-icon { color: var(--accent-2); }

/* ── 16. Callout box ─────────────────────────────────────────────────── */
.nkp-callout {
  background: var(--cream); color: var(--ink);
  border-radius: 10px;
  padding: 40px;
  border: 1px solid rgba(11,15,12,0.08);
  margin-top: 48px;
}
.nkp-callout-dark {
  background: rgba(246,241,228,0.03); color: var(--cream);
  border-radius: 10px;
  padding: 40px;
  border: 1px solid rgba(246,241,228,0.1);
  margin-top: 48px;
}

/* ── 17. Directory CTA ───────────────────────────────────────────────── */
.nkp-directory {
  padding: 72px 0;
  border-bottom: 1px solid rgba(246,241,228,0.08);
}
.nkp-directory-inner {
  display: flex; align-items: center; justify-content: space-between; gap: 48px;
  padding: 40px;
  background: rgba(246,241,228,0.03);
  border: 1px solid rgba(246,241,228,0.1);
  border-radius: 10px;
}
@media (max-width: 700px) { .nkp-directory-inner { flex-direction: column; text-align: center; } }
.nkp-directory-title { font-size: 24px; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 8px; }
.nkp-directory-desc { font-size: 14.5px; color: rgba(246,241,228,0.6); max-width: 40ch; }
.nkp-directory-cta { display: flex; gap: 12px; flex-shrink: 0; }
@media (max-width: 700px) { .nkp-directory-cta { flex-direction: column; width: 100%; } }

/* ── 18. Sync visualization card ─────────────────────────────────────── */
.nkp-sync-card {
  background: rgba(11,15,12,0.04);
  border: 1px solid rgba(11,15,12,0.08);
  border-radius: 10px;
  padding: 20px;
}
.nkp-sync-card.done {
  background: rgba(16,185,129,0.04);
  border-color: rgba(16,185,129,0.15);
}
.nkp-sync-card-head {
  display: flex; align-items: center; gap: 10px; margin-bottom: 14px;
}
.nkp-sync-card-icon {
  width: 28px; height: 28px; border-radius: 6px;
  display: grid; place-items: center;
}
.nkp-sync-card-icon.pos { background: rgba(59,130,246,0.1); border: 1px solid rgba(59,130,246,0.2); }
.nkp-sync-card-icon.pos svg { stroke: #3b82f6; }
.nkp-sync-card-icon.acct { background: rgba(16,185,129,0.1); border: 1px solid rgba(16,185,129,0.2); }
.nkp-sync-card-icon.acct svg { stroke: #10b981; }
.nkp-sync-card-label {
  font-size: 12.5px; font-weight: 600; color: rgba(11,15,12,0.7);
}
.nkp-sync-done {
  margin-left: auto; display: flex; align-items: center; gap: 4px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--accent);
}
.nkp-sync-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.nkp-sync-cell {
  background: rgba(11,15,12,0.03);
  border: 1px solid rgba(11,15,12,0.06);
  border-radius: 6px; padding: 10px 12px;
}
.nkp-sync-cell .lbl { display: block; font-size: 11px; color: rgba(11,15,12,0.5); margin-bottom: 2px; }
.nkp-sync-cell .val { font-size: 16px; font-weight: 700; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; }
.nkp-sync-arrow {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 0;
}
.nkp-sync-line {
  flex: 1; height: 1px; background: rgba(11,15,12,0.1);
}
.nkp-sync-badge {
  display: flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--accent);
  background: rgba(16,185,129,0.06);
  border: 1px solid rgba(16,185,129,0.15);
  border-radius: 999px; padding: 5px 12px;
}
.nkp-sync-badge svg { stroke: var(--accent); }
.nkp-sync-desc {
  font-size: 12.5px; color: rgba(11,15,12,0.6); line-height: 1.45;
}

/* ── 19. ROI calculator ──────────────────────────────────────────────── */
.nkp-roi-inputs {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 24px; margin-top: 48px;
}
@media (max-width: 760px) { .nkp-roi-inputs { grid-template-columns: 1fr; } }
.nkp-roi-input label {
  display: block; font-size: 13px; font-weight: 600;
  color: rgba(246,241,228,0.8); margin-bottom: 12px;
}
.nkp-roi-input input[type="range"] {
  width: 100%; height: 6px;
  -webkit-appearance: none; appearance: none;
  background: rgba(246,241,228,0.12); border-radius: 3px;
  outline: none; cursor: pointer;
}
.nkp-roi-input input[type="range"]::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: #e9c88b; border: 2px solid #0b0f0c;
  cursor: pointer;
}
.nkp-roi-input input[type="range"]::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%;
  background: #e9c88b; border: 2px solid #0b0f0c;
  cursor: pointer;
}
.nkp-roi-range {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 8px; font-size: 11.5px; color: rgba(246,241,228,0.4);
  font-family: var(--mono);
}
.nkp-roi-val { color: #e9c88b; font-weight: 600; }
.nkp-roi-results {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 2px; margin-top: 36px;
  background: rgba(246,241,228,0.06);
  border: 1px solid rgba(246,241,228,0.08);
  border-radius: 8px; overflow: hidden;
}
@media (max-width: 760px) { .nkp-roi-results { grid-template-columns: repeat(2, 1fr); } }
.nkp-roi-result {
  background: #0b0f0c; padding: 28px 24px; text-align: center;
}
.nkp-roi-result .lbl {
  display: block; font-family: var(--mono); font-size: 11px;
  letter-spacing: 0.1em; text-transform: uppercase;
  color: rgba(246,241,228,0.5); margin-bottom: 8px;
}
.nkp-roi-result .val {
  font-size: 32px; font-weight: 700; letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.nkp-roi-result.highlight .val { color: var(--accent-2); }
