/* ============================================================
   DROPGAMBIA — PRODUCTION CSS FINAL
   Gambia iPhone Drop / KoraTheCat glass system
   Ultra-polished for launch. Every pixel intentional.
   ============================================================ */

/* â”€â”€ Reset â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* â”€â”€ Tokens â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
:root{
  --ink:    #1e3a5f;
  --ink2:   #2d4f72;
  --ink3:   #526784;
  --ink4:   #7089a8;
  --ink5:   rgba(30,58,95,.45);
  --blue:   #2563eb;
  --blue-m: #3b82f6;
  --blue-b: #5aa1ff;
  --cyan:   #22d3ee;
  --green:  #10b981;
  --green-b:#34d399;
  --gold:   #fbbf24;
  --orange: #f97316;
  --purple: #7c3aed;
  --white:  #fff;
  --glass-hi:  inset 0 1px 0 rgba(255,255,255,.86);
  --glass-hi2: inset 0 1px 0 rgba(255,255,255,.72);
  --glass-sh:  0 22px 46px rgba(72,110,178,.11);
  --glass-sh2: 0 14px 32px rgba(72,110,178,.08);
  --glow-blue: 0 0 28px rgba(90,161,255,.32),0 0 8px rgba(90,161,255,.16);
  --glow-green:0 0 24px rgba(52,211,153,.32);
  --glow-wa:   0 8px 22px rgba(37,211,102,.36);
  --glow-cta:  0 12px 28px rgba(90,161,255,.40),0 4px 10px rgba(90,161,255,.20);
  --font:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --topbar-h:52px;
  --dock-h:  112px;
  --sticky-h:72px;
  --safe-b:  calc(var(--sticky-h) + var(--dock-h) + env(safe-area-inset-bottom,0px));
  --t:       .18s cubic-bezier(.2,.85,.25,1);
  --t-pop:   .24s cubic-bezier(.22,1.4,.36,1);
  --t-slide: .30s cubic-bezier(.32,.72,0,1);
}

/* â”€â”€ Base â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
html{scroll-behavior:smooth;overflow-x:hidden;width:100%}
body{
  font-family:var(--font);
  background:radial-gradient(120% 80% at 50% -10%,#f7fbff 0%,#e9f2ff 32%,#d6e3ff 62%,#c1d3ff 100%);
  color:var(--ink);
  min-height:100svh;
  overflow-x:hidden;
  width:100%;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  /* Bottom breathing: sticky + dock + safe-area + extra so last card is never hidden */
  padding-bottom:calc(var(--sticky-h) + var(--dock-h) + env(safe-area-inset-bottom,0px) + 24px);
}
/* KoraTheCat light overlays */
body::before{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:4;
  background:
    radial-gradient(circle at 16% 8%,rgba(255,255,255,.86),transparent 18%),
    radial-gradient(circle at 82% 18%,rgba(189,218,255,.72),transparent 24%),
    radial-gradient(circle at 50% 58%,rgba(255,255,255,.38),transparent 35%);
}
body::after{
  content:'';position:fixed;inset:0;pointer-events:none;z-index:4;
  background:
    radial-gradient(circle at 20% 12%,rgba(255,255,255,.28),transparent 22%),
    radial-gradient(circle at 80% 22%,rgba(160,200,255,.15),transparent 28%),
    radial-gradient(circle at 50% 60%,rgba(200,225,255,.12),transparent 40%);
}

/* â”€â”€ Ambient orbs â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.np-ambient{position:fixed;inset:0;pointer-events:none;z-index:3;overflow:hidden}
.np-amb{position:absolute;border-radius:50%;filter:blur(12px);opacity:.72}
.np-amb-a{width:34vw;height:34vw;left:-8vw;top:20vh;background:radial-gradient(circle,rgba(255,255,255,.9),rgba(255,255,255,0))}
.np-amb-b{width:44vw;height:44vw;right:-12vw;top:12vh;background:radial-gradient(circle,rgba(180,213,255,.72),rgba(180,213,255,0))}
.np-amb-c{width:58vw;height:58vw;left:22vw;bottom:-26vw;background:radial-gradient(circle,rgba(206,227,255,.8),rgba(206,227,255,0))}
.np-aurora{position:fixed;inset:-10%;pointer-events:none;z-index:1;opacity:.55;
  background:
    radial-gradient(38% 32% at 18% 22%,rgba(127,180,255,.38),transparent 70%),
    radial-gradient(36% 30% at 82% 18%,rgba(167,139,250,.25),transparent 72%),
    radial-gradient(40% 34% at 78% 78%,rgba(79,148,255,.22),transparent 72%);
  filter:blur(40px);animation:npAuroraDrift 14s ease-in-out infinite alternate}
@keyframes npAuroraDrift{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(2%,-1.5%,0) scale(1.05)}}
.np-vignette{position:fixed;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(ellipse at center,transparent 40%,rgba(10,20,44,.14) 100%)}

/* â”€â”€ Scroll + main â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.np-scroll{position:relative;z-index:5;overflow-x:hidden}
.np-main{padding:0 14px;max-width:430px;margin:0 auto;overflow-x:hidden}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   TOP BAR
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.np-topbar{
  position:sticky;top:0;z-index:100;
  height:var(--topbar-h);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;
  gap:10px;
  background:rgba(247,251,255,.92);
  backdrop-filter:blur(28px) saturate(220%) brightness(1.06);
  -webkit-backdrop-filter:blur(28px) saturate(220%) brightness(1.06);
  border-bottom:1px solid rgba(255,255,255,.75);
  box-shadow:0 1px 0 rgba(72,110,178,.06),var(--glass-hi)}
.np-topbar-left{
  display:flex;align-items:center;gap:8px;
  flex:1;min-width:0;overflow:hidden}
/* CANONICAL LOGO — transparent PNG, no mix-blend needed */
.np-topbar-logo{
  display:block;
  height:30px;
  width:auto;
  max-width:160px;
  object-fit:contain;
  object-position:left center;
  flex-shrink:0;
  /* Transparent background — no blend mode needed */
}
/* Campaign draw badge — subtle pill, right of logo */
.np-topbar-draw-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-size:10.5px;font-weight:700;color:var(--ink3);
  background:rgba(255,255,255,.65);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.75);
  padding:3px 8px;border-radius:999px;
  white-space:nowrap;flex-shrink:0;letter-spacing:.01em;
  min-width:0;overflow:hidden;text-overflow:ellipsis}
.np-topbar-live-dot{
  width:6px;height:6px;border-radius:50%;flex-shrink:0;
  background:var(--green-b);
  box-shadow:0 0 0 2.5px rgba(52,211,153,.22);
  animation:npPulse 2s ease-in-out infinite}
/* Legacy — hidden */
.np-topbar-flag,.np-topbar-live,.np-topbar-text{display:none}
/* WA Help button */
.np-topbar-wa{
  display:inline-flex;align-items:center;gap:5px;
  background:#25d366;color:#fff;
  font-size:12px;font-weight:800;
  padding:7px 12px;border-radius:999px;
  text-decoration:none;flex-shrink:0;
  box-shadow:var(--glow-wa);
  transition:opacity var(--t),transform var(--t-pop);
  white-space:nowrap;
  /* Tap target min 44px height */
  min-height:34px}
.np-topbar-wa:active{opacity:.82;transform:scale(.94)}
/* Small screen: hide draw badge if too tight */
@media(max-width:360px){
  .np-topbar-draw-badge{display:none}
  .np-topbar-logo{max-width:140px}}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   COUNTDOWN
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.np-countdown{
  background:linear-gradient(180deg,rgba(255,255,255,.52),rgba(255,255,255,.26));
  backdrop-filter:blur(14px) saturate(160%);-webkit-backdrop-filter:blur(14px) saturate(160%);
  border-bottom:1px solid rgba(255,255,255,.66);box-shadow:var(--glass-hi);
  padding:7px 16px;display:flex;align-items:center;justify-content:center;
  gap:10px;flex-wrap:wrap;position:relative;z-index:5}
.np-cd-label{font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;color:var(--ink4)}
.np-cd-units{display:flex;align-items:center;gap:6px}
.np-cd-unit{display:flex;flex-direction:column;align-items:center}
.np-cd-num{font-size:20px;font-weight:900;color:var(--ink);line-height:1.05;letter-spacing:-.05em;font-variant-numeric:tabular-nums;min-width:28px;text-align:center}
.np-cd-sep{font-size:18px;font-weight:900;color:var(--blue-b);margin-bottom:5px}
.np-cd-sub{font-size:8px;font-weight:800;color:var(--ink5);text-transform:uppercase;letter-spacing:.07em}
.np-countdown.urgent .np-cd-num{color:var(--orange)}
.np-countdown.ended .np-cd-num{color:var(--green-b)}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   HERO – split layout
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.np-hero{
  margin-top:12px;border-radius:28px;
  overflow:visible;position:relative;
  background:linear-gradient(160deg,rgba(255,255,255,.76) 0%,rgba(255,255,255,.42) 100%);
  backdrop-filter:blur(22px) saturate(220%) brightness(1.08);
  -webkit-backdrop-filter:blur(22px) saturate(220%) brightness(1.08);
  border:1px solid rgba(255,255,255,.82);
  box-shadow:var(--glass-hi),var(--glass-sh),0 4px 60px rgba(139,92,246,.07)}
/* Accent line – rendered as inline element, NOT pseudo-element
   so it doesn't conflict with phone z-index stacking */
.np-hero-accent{
  position:absolute;top:0;left:0;right:0;height:2px;z-index:1;
  background:linear-gradient(90deg,transparent 0%,rgba(90,161,255,.60) 20%,rgba(127,209,255,.80) 45%,rgba(167,139,250,.55) 70%,transparent 100%);
  border-radius:28px 28px 0 0;pointer-events:none}
.np-hero::after{
  content:'';position:absolute;top:0;left:0;right:0;height:50%;z-index:1;pointer-events:none;
  border-radius:28px 28px 22px 22px;background:linear-gradient(180deg,rgba(255,255,255,.28),rgba(255,255,255,0))}

/* Split: text left, phone right */
.np-hero-split{display:flex;align-items:stretch;position:relative;z-index:2;min-height:240px}

/* Text column */
.np-hero-text{flex:1;padding:18px 10px 18px 18px;display:flex;flex-direction:column;justify-content:center;min-width:0}

/* Phone column – bleeds above card but NOT over countdown */
.np-hero-phone{
  flex-shrink:0;width:128px;position:relative;
  overflow:visible;
  display:flex;align-items:flex-end;justify-content:center;
  /* Reduced margin so phone doesn't overlap countdown numbers */
  margin-top:-18px;margin-bottom:-4px;padding-bottom:8px;
  /* z-index above accent line and ::after but not astronomically high */
  z-index:20}
.np-phone-glow{
  position:absolute;inset:-20%;z-index:0;
  background:radial-gradient(ellipse at 50% 50%,rgba(148,100,255,.28) 0%,rgba(167,139,250,.12) 45%,transparent 70%);
  filter:blur(20px);animation:npShadowPulse 4.8s ease-in-out infinite}

/* Real hero image – ALWAYS show (no display:none) */
/* HERO IMAGE – canonical iPhone, always visible, z-index above card border */
.np-hero-img{
  position:relative;
  z-index:20;
  width:110px;height:auto;
  display:block;
  object-fit:contain;
  opacity:1;
  filter:
    drop-shadow(0 8px 28px rgba(139,92,246,.50))
    drop-shadow(0 0 50px rgba(167,139,250,.28))
    drop-shadow(0 2px 8px rgba(90,60,160,.22));
  animation:npiPhoneFloat 4.8s ease-in-out 1s infinite}
.np-hero-img.loaded{opacity:1}

/* Placeholder classes – kept for compat but element removed from HTML */
.np-phone-ph{display:none}

/* Badges */
.np-hero-badges-top{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:9px}
.np-badge-drop{
  display:inline-flex;align-items:center;
  background:linear-gradient(135deg,var(--blue-b) 0%,var(--cyan) 100%);
  color:#fff;font-size:9px;font-weight:900;letter-spacing:.11em;text-transform:uppercase;
  padding:4px 10px;border-radius:999px;
  box-shadow:0 4px 12px rgba(90,161,255,.32),inset 0 1px 0 rgba(255,255,255,.38)}
.np-badge-partner{
  display:inline-flex;align-items:center;
  background:rgba(255,255,255,.70);backdrop-filter:blur(10px);
  color:var(--ink2);font-size:9px;font-weight:800;letter-spacing:.05em;
  padding:4px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.78);box-shadow:var(--glass-hi2)}

/* Copy */
.np-headline{font-size:22px;font-weight:900;line-height:1.04;letter-spacing:-.03em;color:var(--ink);margin-bottom:4px}
.np-headline em{
  font-style:normal;
  background:linear-gradient(120deg,#243854 0%,#1f4f9a 30%,#344763 55%,#1f4f9a 80%,#243854 100%);
  background-size:220% 220%;
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  animation:npShimmer 6s ease-in-out infinite}
.np-hook{font-size:16px;font-weight:800;color:var(--ink);margin-bottom:3px;letter-spacing:-.02em;line-height:1.22}
.np-hook span{color:var(--blue-m);text-shadow:0 0 20px rgba(90,161,255,.22)}
.np-sub{font-size:12px;font-weight:600;color:var(--ink3);line-height:1.45;margin-bottom:10px;letter-spacing:-.01em}
.np-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:8px}
.np-chip{
  display:inline-flex;align-items:center;gap:4px;
  font-size:10.5px;font-weight:700;color:var(--ink3);
  background:rgba(255,255,255,.68);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.78);
  padding:4px 10px;border-radius:999px;
  box-shadow:var(--glass-hi2);letter-spacing:.01em;
  transition:background var(--t)}
/* np-chip-icon: kept for compat but trust chips now use text-only */
.np-chip-icon{width:14px;height:14px;object-fit:contain;display:block;flex-shrink:0;opacity:.85}
.np-chip-live{background:linear-gradient(180deg,rgba(52,211,153,.16),rgba(52,211,153,.07));border-color:rgba(52,211,153,.38);color:#0a7a55}
.np-chip-dot{width:6px;height:6px;border-radius:50%;background:var(--green-b);
  box-shadow:0 0 0 2px rgba(52,211,153,.28),0 0 8px rgba(52,211,153,.40);
  animation:npPulse 1.8s ease-in-out infinite;flex-shrink:0}
.np-chip-partner{
  background:linear-gradient(135deg,rgba(255,255,255,.82),rgba(240,247,255,.65));
  border-color:rgba(90,161,255,.22);color:var(--blue-m);font-weight:800}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PACK SELECTOR – ALWAYS VISIBLE, NO ANIMATION
   These must render immediately when JS builds them.
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
/* ══════════════════════════════════════════════════
   PACK SELECTOR — World-class mobile pricing UX
   No neon. No casino. No gaming animations.
   Calm hierarchy. Strong selected. D500 visibly active.
══════════════════════════════════════════════════ */
.np-packs{margin-top:14px}
.np-packs-label{
  font-size:11px;font-weight:800;color:var(--ink3);
  letter-spacing:.13em;text-transform:uppercase;
  margin-bottom:11px;padding-left:2px}
.np-pack-grid{display:flex;flex-direction:column;gap:10px}

/* ── Pack card — base (D100 calm, valid) ─────────────── */
.np-pack{
  border-radius:20px;
  background:linear-gradient(175deg,rgba(255,255,255,.78) 0%,rgba(255,255,255,.50) 100%);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1.5px solid rgba(255,255,255,.72);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.86),
    0 6px 18px rgba(72,110,178,.07),
    0 1px 3px rgba(72,110,178,.04);
  padding:14px 16px;cursor:pointer;position:relative;
  /* Always visible, no opacity animation */
  opacity:1;
  /* Calm transitions — 180ms, ease, no bounce */
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease,
    background 180ms ease;
  -webkit-tap-highlight-color:transparent;
  user-select:none;outline:none;
  min-height:78px}

/* Hover (desktop only) — subtle lift */
@media(hover:hover){
  .np-pack:hover{
    border-color:rgba(90,161,255,.42);
    background:linear-gradient(175deg,rgba(248,252,255,.92),rgba(232,242,255,.65));
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,.92),
      0 8px 24px rgba(72,110,178,.10),
      0 2px 6px rgba(72,110,178,.06);
    transform:translateY(-1px)}
}

/* Tap — calm scale, no jump */
.np-pack:active{transform:scale(.985)}

/* ── D200 SMART (recommended) — softer hint when not selected ── */
.np-pack.recommended:not(.selected){
  border-color:rgba(90,161,255,.32);
  background:linear-gradient(175deg,rgba(252,254,255,.85),rgba(238,247,255,.60))}

/* ── SELECTED state — calm, premium, soft brand blue ─────
   Style reference: Revolut / Apple Pay / Uber pricing.
   Thin border. Soft icy bg. Subtle inner highlight. No glow. */
.np-pack.selected{
  border-color:rgba(90,161,255,.55);
  border-width:1.5px;
  background:linear-gradient(175deg,rgba(240,248,255,.94) 0%,rgba(226,239,255,.70) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.90),
    0 4px 14px rgba(90,161,255,.10),
    0 1px 3px rgba(72,110,178,.06);
  transform:none}

/* MAX selected — same calm formula in soft purple ─────── */
.np-pack[data-pack="max"].selected{
  border-color:rgba(125,122,236,.50);
  background:linear-gradient(175deg,rgba(244,241,255,.94) 0%,rgba(232,225,255,.68) 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.90),
    0 4px 14px rgba(109,106,246,.12),
    0 1px 3px rgba(72,110,178,.06)}

/* ── D500 MAX — always visibly active even when not selected ── */
.np-pack[data-pack="max"]:not(.selected){
  border-color:rgba(109,106,246,.26);
  background:linear-gradient(175deg,rgba(252,251,255,.85),rgba(244,240,255,.58))}

@media(hover:hover){
  .np-pack[data-pack="max"]:not(.selected):hover{
    border-color:rgba(109,106,246,.42);
    background:linear-gradient(175deg,rgba(250,248,255,.92),rgba(238,232,255,.68))}
}

/* ── BADGE — small premium pill, top-right ────────────── */
.np-pack-badge{
  position:absolute;top:0;right:14px;
  font-size:9px;font-weight:900;letter-spacing:.10em;
  text-transform:uppercase;
  padding:4px 10px;border-radius:0 0 10px 10px;
  white-space:nowrap;
  box-shadow:0 2px 6px rgba(72,110,178,.12)}

/* MOST POPULAR — brand blue/cyan */
.np-pack-badge.accent{
  background:linear-gradient(135deg,#3B82F6 0%,#22d3ee 100%);
  color:#fff;
  box-shadow:0 3px 8px rgba(59,130,246,.28)}

/* BEST CHANCE — premium purple */
.np-pack-badge.value{
  background:linear-gradient(135deg,#6D6AF6 0%,#a78bfa 100%);
  color:#fff;
  box-shadow:0 3px 8px rgba(109,106,246,.30)}

/* Neutral (deprecated — no badge for D100) */
.np-pack-badge.neutral{display:none}

/* ── Pack content ─────────────────────────────────────── */
.np-pack-main{
  display:flex;align-items:center;justify-content:space-between;gap:12px}

.np-pack-name{
  font-size:10px;font-weight:900;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink4);
  margin-bottom:2px;
  transition:color 180ms ease}
.np-pack.recommended .np-pack-name{color:#3B82F6}
.np-pack.selected .np-pack-name{color:#3B82F6}
.np-pack[data-pack="max"] .np-pack-name{color:#6D6AF6}
.np-pack[data-pack="max"].selected .np-pack-name{color:#6D6AF6}

.np-pack-price{
  font-size:30px;font-weight:900;color:var(--ink);
  letter-spacing:-.045em;line-height:1;
  transition:color 180ms ease}
.np-pack-price sup{
  font-size:14px;font-weight:700;color:var(--ink3);
  vertical-align:super;letter-spacing:0}
.np-pack.selected .np-pack-price{color:var(--blue-m)}
.np-pack[data-pack="max"].selected .np-pack-price{color:#5b58e6}

.np-pack-sub{
  font-size:13px;font-weight:700;color:var(--ink3);
  margin-top:3px;letter-spacing:-.005em;
  transition:color 180ms ease}
.np-pack.selected .np-pack-sub{color:var(--ink2)}

/* ── CTA label inside card — always tappable, never grey ── */
.np-pack-cta-lbl{
  font-size:13px;font-weight:900;flex-shrink:0;
  color:#3B82F6;
  white-space:nowrap;margin-left:auto;
  letter-spacing:-.005em;
  transition:color 180ms ease,transform 180ms ease}
.np-pack[data-pack="max"] .np-pack-cta-lbl{color:#6D6AF6}
.np-pack.selected .np-pack-cta-lbl{color:var(--blue-m);font-weight:900}
.np-pack[data-pack="max"].selected .np-pack-cta-lbl{color:#5b58e6}
.np-pack:active .np-pack-cta-lbl{transform:translateX(2px)}

/* Legacy classes (kept for compat) */
.np-pack-row{display:flex;align-items:center;gap:10px}
.np-pack-left{flex:1;min-width:0}
.np-pack-cta{font-size:12px;font-weight:900;flex-shrink:0;color:#3B82F6;white-space:nowrap;margin-left:auto}
.np-pack.selected .np-pack-cta{color:var(--blue-m)}
.np-pack-tagline{font-size:12px;font-weight:600;color:var(--ink4);margin-top:2px}
.np-pack.selected .np-pack-tagline{color:var(--ink2)}
.np-pack-perks{margin-top:9px;padding-top:9px;border-top:1px solid rgba(255,255,255,.55);display:flex;flex-direction:column;gap:3px}
.np-pack-perk{font-size:12px;font-weight:600;color:var(--ink4);display:flex;align-items:center;gap:7px;line-height:1.3}
.np-pack.selected .np-pack-perk{color:var(--ink2)}
.np-pack-perk::before{content:'';width:6px;height:6px;border-radius:50%;flex-shrink:0;background:var(--blue-b);box-shadow:0 0 0 3px rgba(90,161,255,.16)}
.np-pack.selected .np-pack-perk::before{background:var(--blue-m)}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PAYMENT ROW + PARTNER
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.np-pay-row{
  margin-top:12px;padding:9px 20px;border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.58),rgba(255,255,255,.30));
  backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.72);
  box-shadow:var(--glass-hi2),var(--glass-sh2);
  display:flex;align-items:center;justify-content:center;gap:8px}
/* Pay label */
.np-pay-label{font-size:11px;font-weight:700;color:var(--ink4);letter-spacing:.03em}
/* Wave-only trust row (home screen) */
.np-pay-wave-row{display:inline-flex;align-items:center;gap:5px}
.np-pay-wave-name{font-size:13px;font-weight:800;color:var(--ink2);letter-spacing:-.01em}
/* Wave inline logo */
.np-wave-inline-wrap{display:inline-flex;align-items:center;line-height:0;flex-shrink:0}
.np-wave-inline{
  height:20px;width:auto;object-fit:contain;display:block;
  /* Logo has transparent background — no blend mode needed */
  opacity:.90}
/* Legacy refs */
.np-pay-methods-inline{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:center}
.np-pay-sep{font-size:11px;color:var(--ink5);font-weight:400;line-height:1}
.np-pay-method-item{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;color:var(--ink3);letter-spacing:.01em}
.np-pay-method-active{color:var(--ink2);font-weight:800}
.np-pay-method-soon{color:var(--ink5);font-weight:600}
.np-wave-logo-wrap{display:inline-flex;align-items:center;line-height:0}
.np-wave-logo-pay{height:20px;width:auto;mix-blend-mode:multiply;opacity:.80;display:block}
.np-pay-method{font-size:12px;font-weight:800;color:var(--ink2)}
.np-pay-dot{font-size:10px;color:var(--ink5)}
.np-partner{margin-top:6px;display:flex;align-items:center;justify-content:center;gap:5px}
.np-partner-text{font-size:11px;color:var(--ink4)}
.np-partner-name{font-size:11px;font-weight:800;color:var(--ink2)}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   STICKY CTA – Premium glass action bar V2
   Rebuilt 2026-05-27 as floating pill above dock.
   Container is a floating rounded card, not a flat bar.
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.np-sticky{
  position:fixed;
  bottom:calc(var(--dock-h) + 10px);
  left:0;right:0;
  z-index:90;
  pointer-events:none}
/* Sticky inner pill — single definition, glass card style */
.np-sticky-inner{
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:11px 10px 11px 16px;
  background:rgba(245,250,255,.88);
  backdrop-filter:blur(20px) saturate(200%) brightness(1.05);
  -webkit-backdrop-filter:blur(20px) saturate(200%) brightness(1.05);
  border:1px solid rgba(255,255,255,.65);
  border-radius:24px;
  box-shadow:
    0 12px 34px rgba(36,92,180,.13),
    0 3px 10px rgba(36,92,180,.05),
    inset 0 1px 0 rgba(255,255,255,.75);
  /* Width: full screen minus 28px margins, max 430px */
  width:calc(100% - 28px);
  max-width:430px;
  margin:0 auto;
  overflow:hidden;
  pointer-events:all}
.np-sticky-left{flex:1;min-width:0;overflow:hidden}
.np-sticky-label{
  font-size:11px;font-weight:600;color:var(--ink4);
  letter-spacing:.01em;margin-bottom:2px;
  text-transform:none;line-height:1}
.np-sticky-title{
  font-size:13px;font-weight:600;color:var(--ink3);
  line-height:1.1;letter-spacing:-.01em;margin:0}
.np-sticky-title strong{
  font-size:19px;font-weight:900;color:var(--ink);
  letter-spacing:-.035em;display:inline}
.np-sticky-sub{
  font-size:11px;font-weight:600;color:var(--ink4);
  margin-top:1px;letter-spacing:-.01em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   BUTTON SYSTEM V2 – DropGambia Production
   Primary / Secondary / Tertiary / Loading / Disabled
   Locked 2026-05-27. No browser defaults.
   Min tap target 44px. Pill shape. Inter 800.
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ Shared reset – applied to ALL np-btn-* â”€â”€ */
.np-btn-cta,
.np-btn-secondary,
.np-btn-submit,
.np-btn-wa,
.np-btn-share{
  -webkit-appearance:none;appearance:none;
  -webkit-tap-highlight-color:transparent;
  user-select:none;touch-action:manipulation;
  font-family:inherit;text-align:center;
  display:inline-flex;align-items:center;justify-content:center;
  gap:7px;border-radius:999px;cursor:pointer;
  white-space:nowrap;text-decoration:none;
  transition:
    transform 120ms ease,
    box-shadow 120ms ease,
    opacity 120ms ease,
    background 120ms ease;
  /* Motion reduction */
  @media(prefers-reduced-motion:reduce){transition:none}}

/* â”€â”€ PRIMARY – main conversion action â”€â”€ */
/* Uses: sticky CTA, checkout submit, send proof, ticket confirm */
.np-btn-cta{
  background:linear-gradient(135deg,#2F80ED 0%,#3B82F6 58%,#6D6AF6 100%);
  background-size:200% 200%;
  color:#fff;font-size:14px;font-weight:800;letter-spacing:-.01em;
  padding:13px 22px;min-height:46px;flex-shrink:0;
  border:1px solid rgba(255,255,255,.38);
  box-shadow:
    0 8px 18px rgba(47,128,237,.22),
    0 2px 6px rgba(14,20,36,.08),
    inset 0 1px 0 rgba(255,255,255,.34);
  animation:npCtaPan 8s ease-in-out infinite}
.np-btn-cta:hover{
  filter:brightness(1.04);
  box-shadow:
    0 10px 24px rgba(47,128,237,.26),
    0 2px 8px rgba(14,20,36,.10),
    inset 0 1px 0 rgba(255,255,255,.34)}
.np-btn-cta:active{
  transform:scale(.975);
  box-shadow:0 3px 10px rgba(47,128,237,.18),inset 0 1px 0 rgba(255,255,255,.22)}
.np-btn-cta svg{flex-shrink:0;opacity:.92}

/* Loading state */
.np-btn-cta.loading,.np-btn-submit.loading{
  opacity:.78;cursor:wait;pointer-events:none;
  animation:npCtaPan 8s ease-in-out infinite,npLoadPulse 1.4s ease-in-out infinite}
/* Disabled state – no grey browser default */
.np-btn-cta:disabled,.np-btn-cta.disabled,
.np-btn-submit:disabled,.np-btn-submit.disabled{
  opacity:.46;cursor:not-allowed;pointer-events:none;
  transform:none;
  box-shadow:0 2px 8px rgba(47,128,237,.10),inset 0 1px 0 rgba(255,255,255,.20)}

/* Primary full-width (checkout, form submit) */
.np-btn-submit{
  width:100%;padding:15px 24px;min-height:50px;
  background:linear-gradient(135deg,#2F80ED 0%,#3B82F6 58%,#6D6AF6 100%);
  background-size:200% 200%;
  color:#fff;font-size:15px;font-weight:800;letter-spacing:-.01em;
  border:1px solid rgba(255,255,255,.34);
  box-shadow:
    0 8px 20px rgba(47,128,237,.22),
    0 2px 6px rgba(14,20,36,.08),
    inset 0 1px 0 rgba(255,255,255,.30);
  margin-top:6px;
  animation:npCtaPan 8s ease-in-out infinite}
.np-btn-submit:active{transform:scale(.975);opacity:.90}
.np-btn-submit:disabled{
  opacity:.46;cursor:not-allowed;transform:none;
  box-shadow:0 2px 8px rgba(47,128,237,.10)}

@keyframes npCtaPan{
  0%,100%{background-position:0% 50%}
  50%{background-position:100% 50%}}
@keyframes npLoadPulse{
  0%,100%{opacity:.78}50%{opacity:.55}}

/* â”€â”€ WHATSAPP PRIMARY – send proof â”€â”€ */
/* Inherits primary shape but WhatsApp green */
.np-btn-wa{
  width:100%;padding:15px 24px;min-height:50px;
  background:#1FAD4B;
  color:#fff;font-size:15px;font-weight:800;letter-spacing:-.01em;
  border:1px solid rgba(255,255,255,.24);
  box-shadow:
    0 6px 18px rgba(31,173,75,.28),
    inset 0 1px 0 rgba(255,255,255,.18)}
.np-btn-wa:hover{filter:brightness(1.05)}
.np-btn-wa:active{transform:scale(.975);opacity:.90}

/* â”€â”€ SECONDARY – supporting actions â”€â”€ */
/* Uses: Check Ticket, View Rules, View Winners, How It Works */
.np-btn-secondary{
  background:rgba(255,255,255,.68);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  color:var(--ink);font-size:14px;font-weight:700;letter-spacing:-.01em;
  padding:12px 20px;min-height:44px;
  border:1px solid rgba(255,255,255,.72);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65),0 2px 8px rgba(72,110,178,.06)}
.np-btn-secondary:hover{background:rgba(255,255,255,.82)}
.np-btn-secondary:active{transform:scale(.975);opacity:.90}
.np-btn-secondary.wide{width:100%}

/* â”€â”€ SHARE – outline/ghost â”€â”€ */
.np-btn-share{
  width:100%;padding:13px 20px;min-height:46px;
  background:rgba(228,240,255,.45);
  color:var(--blue-m);font-size:14px;font-weight:700;
  border:1.5px solid rgba(90,161,255,.38);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.65)}
.np-btn-share:hover{background:rgba(228,240,255,.68)}
.np-btn-share:active{transform:scale(.975);background:rgba(228,240,255,.78)}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   BOTTOM DOCK – KoraTheCat V3400 exact
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.np-dock{
  position:fixed;left:50%;bottom:calc(16px + env(safe-area-inset-bottom));
  transform:translateX(-50%) translateY(20px);z-index:100;
  display:flex;align-items:center;justify-content:space-around;
  /* Full width minus margins, max 480, never overflow viewport */
  width:min(calc(100% - 28px),480px);max-width:calc(100vw - 28px);
  padding:12px 18px;border-radius:999px;isolation:isolate;
  background:linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.02)) !important;
  backdrop-filter:blur(24px) saturate(240%) brightness(1.12) !important;
  -webkit-backdrop-filter:blur(24px) saturate(240%) brightness(1.12) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.80),
    inset 0 -1px 0 rgba(255,255,255,.06),
    0 8px 32px rgba(72,110,178,.12),
    0 2px 12px rgba(72,110,178,.06) !important;
  opacity:0;animation:npDockEnter .22s cubic-bezier(.15,.7,.2,1) .5s both}
.np-dock::before{
  content:'';position:absolute;inset:1px 1px auto 1px;height:44%;
  border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.32),rgba(255,255,255,0));
  pointer-events:none;opacity:.55}
/* Dock items — min 44px tap target */
.np-dock-item{
  display:flex;flex-direction:column;align-items:center;gap:4px;
  background:none;border:none;cursor:pointer;
  flex:1;padding:4px 4px;
  border-radius:16px;
  min-width:44px;min-height:44px;
  justify-content:center;
  transition:background var(--t),transform var(--t-pop);
  -webkit-tap-highlight-color:transparent}
.np-dock-item:active{background:rgba(72,110,178,.10);transform:scale(.88)}
/* Legacy SVG fallback */
.np-dock-item svg{width:22px;height:22px}
/* CANONICAL DOCK ICONS — 28px, white-bg PNGs use multiply to blend on dock */
.np-dock-icon{
  width:28px;height:28px;object-fit:contain;display:block;
  mix-blend-mode:multiply;
  opacity:.88;
  transition:opacity var(--t),transform var(--t-pop)}
.np-dock-item:active .np-dock-icon{opacity:1;transform:scale(.92)}
/* Dock label */
.np-dock-item span{
  font-size:10px;font-weight:800;color:var(--ink3);
  letter-spacing:.03em;white-space:nowrap;line-height:1}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   OVERLAY + SHEETS
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.np-overlay{
  position:fixed;inset:0;z-index:300;
  background:rgba(175,205,250,.22);backdrop-filter:blur(8px) saturate(150%);-webkit-backdrop-filter:blur(8px) saturate(150%);
  opacity:0;pointer-events:none;transition:opacity .22s ease}
.np-overlay.open{opacity:1;pointer-events:all}
.np-sheet{
  position:fixed;left:0;right:0;bottom:0;z-index:301;
  border-radius:28px 28px 0 0;
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(245,250,255,.97));
  backdrop-filter:blur(32px) saturate(240%) brightness(1.08);-webkit-backdrop-filter:blur(32px) saturate(240%) brightness(1.08);
  border-top:1px solid rgba(255,255,255,.86);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.94),0 -10px 70px rgba(72,110,178,.14),0 -2px 16px rgba(72,110,178,.06);
  max-height:92dvh;overflow-y:auto;overscroll-behavior:contain;
  transform:translateY(105%);transition:transform var(--t-slide);
  -webkit-overflow-scrolling:touch;padding-bottom:env(safe-area-inset-bottom,0px)}
.np-sheet.open{transform:translateY(0)}
.np-sheet-handle{width:36px;height:4px;border-radius:2px;background:rgba(72,110,178,.20);margin:12px auto 0}
.np-sheet-head{
  display:flex;align-items:center;justify-content:space-between;padding:14px 18px 11px;
  border-bottom:1px solid rgba(72,110,178,.07);
  position:sticky;top:0;z-index:2;background:rgba(245,250,255,.94);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
.np-sheet-title{font-size:18px;font-weight:900;color:var(--ink);letter-spacing:-.025em}
.np-sheet-close{width:30px;height:30px;border-radius:50%;background:rgba(72,110,178,.09);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink2);font-size:16px;transition:background var(--t);-webkit-tap-highlight-color:transparent}
.np-sheet-close:active{background:rgba(72,110,178,.18)}
.np-sheet-body{padding:16px 18px 28px}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   CHECKOUT FORM
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
.np-co-bar{
  display:flex;align-items:center;justify-content:space-between;
  padding:12px 14px;border-radius:18px;gap:10px;margin-bottom:16px;
  background:linear-gradient(180deg,rgba(224,238,255,.76),rgba(204,224,255,.46));
  border:1px solid rgba(90,161,255,.26);box-shadow:inset 0 1px 0 rgba(255,255,255,.88)}
.np-co-bar-name{font-size:13px;font-weight:800;color:var(--ink2)}
.np-co-bar-desc{font-size:11px;font-weight:600;color:var(--ink4);margin-top:2px}
.np-co-bar-price{font-size:24px;font-weight:900;color:var(--blue);letter-spacing:-.03em;white-space:nowrap}
.np-co-bar-price sup{font-size:13px;color:var(--ink3)}
/* Wave preselected card in simplified checkout */
.np-co-wave-card{
  display:flex;align-items:center;gap:14px;
  padding:14px 16px;border-radius:18px;
  background:linear-gradient(135deg,rgba(0,176,220,.07),rgba(0,200,240,.04));
  border:1.5px solid rgba(0,190,220,.40);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.88),0 0 0 2px rgba(0,190,220,.10),0 4px 16px rgba(0,180,210,.10);
  margin-bottom:16px}
.np-co-wave-name{font-size:16px;font-weight:900;color:var(--ink)}
.np-co-wave-num{font-size:12px;font-weight:600;color:#00b4cc;margin-top:2px}
.np-form-group{margin-bottom:13px}
.np-form-label{display:block;font-size:11px;font-weight:800;color:var(--ink3);letter-spacing:.07em;text-transform:uppercase;margin-bottom:6px}
.np-form-input,.np-form-select{
  width:100%;background:rgba(255,255,255,.80);border:1.5px solid rgba(72,110,178,.18);
  border-radius:14px;color:var(--ink);font-size:16px;font-weight:500;font-family:var(--font);
  padding:13px 14px;outline:none;appearance:none;-webkit-appearance:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.94);transition:border-color var(--t),box-shadow var(--t)}
.np-form-input::placeholder{color:var(--ink5)}
.np-form-input:focus,.np-form-select:focus{border-color:var(--blue-m);box-shadow:inset 0 1px 0 rgba(255,255,255,.94),0 0 0 3px rgba(90,161,255,.14)}
.np-form-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23526784' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-color:rgba(255,255,255,.80);padding-right:36px;cursor:pointer}
.np-form-select option{background:#fff;color:var(--ink)}
/* Wave-only payment – full width single button */
.np-pay-grid{display:flex;flex-direction:column;gap:8px}
.np-pay-btn{
  width:100%;
  display:flex;align-items:center;justify-content:center;
  padding:14px 18px;border-radius:16px;min-height:64px;
  border:1.5px solid rgba(72,110,178,.16);background:rgba(255,255,255,.66);box-shadow:var(--glass-hi2);
  cursor:pointer;transition:all var(--t);-webkit-tap-highlight-color:transparent}
.np-pay-btn:active{transform:scale(.97)}
/* Wave selected state */
.np-pay-btn-wave{
  border-color:rgba(0,190,220,.55);
  background:linear-gradient(135deg,rgba(0,190,220,.08) 0%,rgba(0,210,240,.04) 100%);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.92),0 0 0 2px rgba(0,190,220,.15),0 4px 20px rgba(0,180,210,.12)}
.np-wave-btn-inner{display:flex;align-items:center;gap:14px;width:100%}
/* Wave logo — checkout. Transparent PNG, no blend mode needed. */
.np-wave-logo{
  height:30px;width:auto;object-fit:contain;flex-shrink:0;
  opacity:.92}
/* No blend override for dark mode in checkout – checkout is always light glass */
.np-wave-btn-inner .np-pn{font-size:16px;font-weight:900;color:var(--ink);text-align:left}
.np-wave-btn-inner .np-pb{font-size:11px;font-weight:600;color:#00b4cc;margin-top:2px}
.np-wave-check{margin-left:auto;width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,#00c8d8,#00a8c0);color:#fff;font-size:14px;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(0,180,210,.35);flex-shrink:0}
.np-pay-btn:active{transform:scale(.96)}
.np-pay-btn.selected{border-color:rgba(90,161,255,.58);background:linear-gradient(180deg,rgba(222,236,255,.90),rgba(202,222,255,.60));box-shadow:inset 0 1px 0 rgba(255,255,255,.92),0 0 0 2px rgba(90,161,255,.18),var(--glow-blue)}
.np-pay-btn.wave-first{border-color:rgba(90,161,255,.28)}
.np-pay-btn.wave-first .np-pn{color:var(--blue-m)}
.np-pay-btn.disabled{opacity:.36;cursor:not-allowed;pointer-events:none}
.np-pi{font-size:20px;line-height:1}
.np-pn{font-size:12px;font-weight:800;color:var(--ink2);text-align:center}
.np-pb{font-size:9px;font-weight:700;color:var(--ink4)}
.np-field-error{font-size:12px;color:#b91c1c;font-weight:700;margin-top:4px;display:none}
.np-field-error.show{display:block}
/* np-btn-submit – see button system above (line ~393) */
/* np-btn-submit states handled in button system */

/* Payment instructions */
.np-pi-wrap{display:flex;flex-direction:column;gap:12px}
.np-pending-card{padding:15px 16px;border-radius:17px;text-align:center;background:linear-gradient(180deg,rgba(255,220,80,.10),rgba(255,220,80,.04));border:1px solid rgba(245,158,11,.22);box-shadow:inset 0 1px 0 rgba(255,255,255,.84)}
.np-pending-icon{font-size:30px;line-height:1;margin-bottom:7px}
.np-pending-title{font-size:17px;font-weight:900;color:#92400e;margin-bottom:3px}
.np-pending-sub{font-size:13px;font-weight:500;color:var(--ink2);line-height:1.5}
.np-amount-row{display:flex;flex-direction:column;align-items:center;padding:14px;border-radius:16px;background:linear-gradient(180deg,rgba(224,238,255,.76),rgba(204,224,255,.46));border:1px solid rgba(90,161,255,.24);box-shadow:inset 0 1px 0 rgba(255,255,255,.88)}
.np-amount-val{font-size:40px;font-weight:900;color:var(--blue);letter-spacing:-.05em;line-height:1;display:flex;align-items:baseline;gap:3px}
.np-amount-cur{font-size:18px;font-weight:700;color:var(--ink3)}
.np-amount-method{font-size:12px;font-weight:700;color:var(--ink4);margin-top:4px}
.np-steps-box{border-radius:17px;overflow:hidden;border:1px solid rgba(72,110,178,.11)}
.np-step-row{display:flex;gap:12px;align-items:flex-start;padding:13px 14px;border-bottom:1px solid rgba(72,110,178,.07);background:rgba(255,255,255,.62)}
.np-step-row:last-child{border-bottom:none}
.np-step-num{width:28px;height:28px;border-radius:50%;flex-shrink:0;background:linear-gradient(135deg,var(--blue-m),var(--cyan));color:#fff;font-size:13px;font-weight:900;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px rgba(90,161,255,.30)}
.np-step-body{flex:1;min-width:0}
.np-step-title{font-size:14px;font-weight:800;color:var(--ink);margin-bottom:2px}
.np-step-desc{font-size:12px;color:var(--ink3);line-height:1.4}
.np-num-row{display:flex;align-items:center;gap:9px;margin-top:6px;flex-wrap:wrap}
.np-num-val{font-size:19px;font-weight:900;color:var(--blue);font-family:'Courier New',monospace;letter-spacing:.04em}
.np-copy-btn{background:rgba(90,161,255,.12);border:1px solid rgba(90,161,255,.26);color:var(--blue-m);font-size:12px;font-weight:800;padding:5px 12px;border-radius:999px;cursor:pointer;transition:background var(--t),color var(--t);-webkit-tap-highlight-color:transparent}
.np-copy-btn:active{background:var(--blue-m);color:#fff}
.np-ref-box{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;padding:12px 14px;border-radius:14px;background:rgba(224,238,255,.62);border:1px solid rgba(90,161,255,.22);box-shadow:inset 0 1px 0 rgba(255,255,255,.86)}
.np-ref-label{font-size:10px;font-weight:800;color:var(--blue-m);text-transform:uppercase;letter-spacing:.09em}
.np-ref-row{display:flex;align-items:center;gap:9px}
.np-ref-val{font-size:14px;font-weight:900;color:var(--ink);font-family:'Courier New',monospace;letter-spacing:.04em}
.np-pi-pack-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-radius:14px;background:rgba(255,255,255,.58);border:1px solid rgba(72,110,178,.12);box-shadow:inset 0 1px 0 rgba(255,255,255,.92);gap:10px}
.np-pi-pack-name{font-size:12px;font-weight:800;color:var(--ink2)}
.np-pi-pack-tickets{font-size:11px;font-weight:600;color:var(--ink4);margin-top:1px}
.np-pi-pack-price{font-size:19px;font-weight:900;color:var(--blue);letter-spacing:-.03em;white-space:nowrap}
.np-pi-pack-price sup{font-size:11px;color:var(--ink3)}
.np-pi-help{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 14px;border-radius:13px;background:rgba(255,255,255,.50);border:1px solid rgba(72,110,178,.12);font-size:13px;font-weight:700;color:var(--ink3);text-decoration:none;transition:background var(--t);-webkit-tap-highlight-color:transparent}
.np-pi-help:active{background:rgba(222,236,255,.66)}
.np-pi-help span{color:var(--blue-m)}
/* np-btn-wa – see button system (WhatsApp Primary section) */
/* np-btn-share – see button system (Share/Ghost section) */

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   PREMIUM HOLOGRAPHIC TICKET CARD
   Gambia iPhone Drop – DGW1-XXXXXX
   Inspired by Uiverse concept – adapted for mobile,
   performance-safe (no SVG filters), pure CSS glass.
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* Outer wrapper – glow + float animation */
.np-ticket-card{
  position:relative;
  width:100%;max-width:380px;
  margin:0 auto;
  filter:
    drop-shadow(0 2px 4px rgba(90,60,180,.15))
    drop-shadow(0 8px 24px rgba(90,60,180,.22))
    drop-shadow(0 24px 48px rgba(90,60,180,.18));
  animation:npTicketFloat 3.5s ease-in-out infinite}

@keyframes npTicketFloat{
  0%,100%{transform:translateY(0) scale(1);filter:drop-shadow(0 2px 4px rgba(90,60,180,.15)) drop-shadow(0 8px 24px rgba(90,60,180,.22)) drop-shadow(0 24px 48px rgba(90,60,180,.18))}
  50%{transform:translateY(-7px) scale(1.01);filter:drop-shadow(0 4px 8px rgba(90,60,180,.10)) drop-shadow(0 14px 36px rgba(90,60,180,.15)) drop-shadow(0 36px 64px rgba(90,60,180,.12))}}

/* Main ticket body */
.np-ticket-inner{
  position:relative;
  border-radius:22px;
  overflow:hidden;
  background:#fff;
  border:1.5px solid rgba(180,160,240,.50)}

/* â”€â”€ Holographic sheen layer – CSS only, no SVG filter â”€â”€ */
.np-ticket-inner::before{
  content:'';
  position:absolute;inset:0;
  border-radius:21px;
  background:
    conic-gradient(
      from 210deg at 65% 45%,
      rgba(200,190,255,0.00)  0deg,
      rgba(167,139,250,0.22)  35deg,
      rgba(140,200,255,0.28)  70deg,
      rgba(200,230,255,0.18) 110deg,
      rgba(220,200,255,0.12) 150deg,
      rgba(167,139,250,0.10) 190deg,
      rgba(200,190,255,0.00) 230deg),
    linear-gradient(155deg,
      rgba(255,255,255,0.55) 0%,
      rgba(210,195,255,0.14) 35%,
      rgba(185,225,255,0.18) 65%,
      rgba(255,255,255,0.50) 100%);
  pointer-events:none;
  z-index:1;
  mix-blend-mode:screen;
  animation:npHoloShift 5s ease-in-out infinite alternate}

@keyframes npHoloShift{
  from{opacity:.75;background-position:0% 50%}
  to  {opacity:1.00;background-position:100% 50%}}

/* Top wet-glass shine streak */
.np-ticket-inner::after{
  content:'';
  position:absolute;top:0;left:0;right:0;height:46%;
  border-radius:21px 21px 50% 50%;
  background:linear-gradient(180deg,rgba(255,255,255,.40),rgba(255,255,255,.00));
  pointer-events:none;z-index:2}

/* â”€â”€ Left / right notches (perforation effect) â”€â”€ */
.np-ticket-notch-l,.np-ticket-notch-r{
  position:absolute;top:50%;transform:translateY(-50%);
  width:20px;height:20px;border-radius:50%;
  /* Background matches page bg for cut-out illusion */
  background:radial-gradient(circle,#d8e8ff 0%,#c4d8ff 100%);
  box-shadow:inset 0 0 0 1.5px rgba(160,140,230,.30);
  z-index:10}
.np-ticket-notch-l{left:-10px}
.np-ticket-notch-r{right:-10px}

/* â”€â”€ Header: brand + ACTIVE badge â”€â”€ */
.np-ticket-head{
  position:relative;z-index:3;
  padding:16px 20px 12px;
  display:flex;align-items:center;justify-content:space-between}

.np-ticket-brand{
  font-family:var(--font);
  font-size:10px;font-weight:900;letter-spacing:.16em;text-transform:uppercase;
  color:rgba(100,80,160,.70)}

.np-ticket-status-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:999px;
  background:linear-gradient(135deg,rgba(16,185,129,.15),rgba(52,211,153,.08));
  border:1px solid rgba(52,211,153,.40);
  font-size:10px;font-weight:900;color:#065f46;letter-spacing:.08em;text-transform:uppercase;
  box-shadow:0 0 12px rgba(52,211,153,.20)}

.np-ticket-status-dot{
  width:7px;height:7px;border-radius:50%;
  background:var(--green-b);
  box-shadow:0 0 0 2.5px rgba(52,211,153,.30),0 0 8px rgba(52,211,153,.55);
  animation:npPulse 1.8s ease-in-out infinite;flex-shrink:0}

/* â”€â”€ Event / prize title â”€â”€ */
.np-ticket-title-area{
  position:relative;z-index:3;
  padding:0 20px 12px}

.np-ticket-event{
  font-family:var(--font);
  font-size:20px;font-weight:900;color:var(--ink);letter-spacing:-.03em;line-height:1.12}

.np-ticket-drop{
  font-size:12px;font-weight:600;color:var(--ink4);margin-top:3px}

/* â”€â”€ Perforation dashed line â”€â”€ */
.np-ticket-perf{
  position:relative;z-index:3;
  border:none;
  border-top:1.5px dashed rgba(150,120,240,.30);
  margin:0 20px}

/* â”€â”€ Ticket IDs – the hero element â”€â”€ */
.np-ticket-ids-area{
  position:relative;z-index:3;
  padding:14px 20px 16px}

.np-ticket-id-label{
  font-size:9px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(120,80,200,.65);margin-bottom:8px}

.np-ticket-ids-list{display:flex;flex-direction:column;gap:6px}

/* Single ticket – BIG and prominent */
.np-ticket-id-val{
  font-family:'Courier New',Courier,monospace;
  font-size:26px;font-weight:900;
  color:#4c1d95;
  letter-spacing:.10em;line-height:1.15;
  /* Subtle purple gradient on text */
  background:linear-gradient(135deg,#4c1d95 0%,#6d28d9 50%,#7c3aed 100%);
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}

/* Multiple tickets – slightly smaller */
.np-ticket-ids-list.multi .np-ticket-id-val{
  font-size:18px;letter-spacing:.08em}

/* â”€â”€ Footer: draw info + mini barcode â”€â”€ */
.np-ticket-footer{
  position:relative;z-index:3;
  padding:12px 20px 18px;
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px}

.np-ticket-meta{flex:1}
.np-ticket-meta-row{font-size:12px;font-weight:700;color:var(--ink3);line-height:1.7}
.np-ticket-meta-val{font-weight:900;color:var(--ink);font-size:13px}

/* Decorative barcode */
.np-ticket-barcode{flex-shrink:0;display:flex;align-items:flex-end;gap:2.5px;height:38px}
.np-ticket-barcode span{display:block;width:2.5px;background:linear-gradient(180deg,rgba(91,33,182,.55),rgba(109,40,217,.35));border-radius:1.5px}
.np-ticket-barcode span:nth-child(1){height:100%}
.np-ticket-barcode span:nth-child(2){height:60%}
.np-ticket-barcode span:nth-child(3){height:80%}
.np-ticket-barcode span:nth-child(4){height:45%}
.np-ticket-barcode span:nth-child(5){height:100%}
.np-ticket-barcode span:nth-child(6){height:70%;width:5px}
.np-ticket-barcode span:nth-child(7){height:85%}
.np-ticket-barcode span:nth-child(8){height:50%}
.np-ticket-barcode span:nth-child(9){height:75%}
.np-ticket-barcode span:nth-child(10){height:100%;width:4px}
.np-ticket-barcode span:nth-child(11){height:55%}
.np-ticket-barcode span:nth-child(12){height:90%}
.np-ticket-barcode span:nth-child(13){height:65%}
.np-ticket-barcode span:nth-child(14){height:100%}
.np-ticket-barcode span:nth-child(15){height:50%;width:5px}

/* â”€â”€ Compact (check ticket panel) â”€â”€ */
.np-ticket-card.compact{animation:none;filter:drop-shadow(0 4px 16px rgba(90,60,180,.18))}
.np-ticket-card.compact .np-ticket-event{font-size:16px}
.np-ticket-card.compact .np-ticket-id-val{font-size:20px}
.np-ticket-card.compact .np-ticket-ids-list.multi .np-ticket-id-val{font-size:15px}
.np-ticket-card.compact .np-ticket-head{padding:12px 16px 9px}
.np-ticket-card.compact .np-ticket-title-area{padding:0 16px 9px}
.np-ticket-card.compact .np-ticket-ids-area{padding:10px 16px 12px}
.np-ticket-card.compact .np-ticket-footer{padding:9px 16px 14px}
.np-ticket-card.compact .np-ticket-barcode{height:28px}
.np-ticket-card.compact .np-ticket-notch-l{left:-8px;width:16px;height:16px}
.np-ticket-card.compact .np-ticket-notch-r{right:-8px;width:16px;height:16px}

/* Check ticket result */
.np-check-result{margin-top:13px;padding:0;border-radius:16px;display:none;background:none;border:none;box-shadow:none}
.np-check-result.show{display:block}
/* When showing active ticket – no extra wrapper padding needed */
.np-check-result .np-check-status{font-size:12px;font-weight:900;padding:4px 11px;border-radius:999px;display:inline-block;margin-bottom:9px}
.np-check-status.pending{background:rgba(245,158,11,.12);color:#92400e;border:1px solid rgba(245,158,11,.24)}
.np-check-status.confirmed{background:rgba(52,211,153,.12);color:#065f46;border:1px solid rgba(52,211,153,.26);box-shadow:0 0 12px rgba(52,211,153,.20)}
.np-check-status.proof{background:rgba(90,161,255,.12);color:var(--blue-m);border:1px solid rgba(90,161,255,.26)}
.np-check-meta{font-size:13px;color:var(--ink2);line-height:1.6}
.np-check-meta strong{color:var(--ink)}
.np-check-pending-msg{font-size:13px;font-weight:600;color:#92400e;line-height:1.4;margin-top:6px}
.np-check-proof-msg{font-size:13px;font-weight:600;color:var(--blue-m);line-height:1.4;margin-top:6px}

/* Winners / Rules */
.np-winners-empty{text-align:center;padding:34px 0}
.np-winners-empty-icon{font-size:54px;margin-bottom:12px}
.np-winners-empty-title{font-size:20px;font-weight:900;color:var(--ink);margin-bottom:5px}
.np-winners-empty-sub{font-size:14px;color:var(--ink3);line-height:1.5}
.np-rules-list{display:flex;flex-direction:column;gap:13px}
.np-rule-item{display:flex;gap:12px;align-items:flex-start}
.np-rule-icon{font-size:16px;flex-shrink:0;margin-top:1px}
.np-rule-text{font-size:14px;font-weight:500;color:var(--ink2);line-height:1.5}
.np-rules-terms{margin-top:20px;text-align:center}
.np-rules-terms a{font-size:13px;color:var(--blue-m);font-weight:700;text-decoration:none}

/* Shared utilities */
.np-divider{height:1px;background:rgba(72,110,178,.09);margin:13px 0}
.np-info-box{padding:12px 14px;border-radius:14px;background:rgba(222,236,255,.48);border:1px solid rgba(90,161,255,.18);font-size:13px;font-weight:500;color:var(--ink3);text-align:center;line-height:1.5}
.np-info-box a{color:var(--blue-m);font-weight:700;text-decoration:none}
.np-toast{position:fixed;bottom:calc(var(--sticky-h) + var(--dock-h) + 14px + env(safe-area-inset-bottom,0px));left:50%;transform:translateX(-50%) translateY(12px);background:rgba(28,42,68,.93);color:#fff;backdrop-filter:blur(16px);font-size:13px;font-weight:700;padding:10px 20px;border-radius:999px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;z-index:600}
.np-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   ANIMATIONS
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
@keyframes npPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.48;transform:scale(.74)}}
@keyframes npShimmer{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
@keyframes npiPhoneFloat{0%,100%{transform:translateY(0) rotate(0deg)}25%{transform:translateY(-4px) rotate(.2deg)}50%{transform:translateY(-8px) rotate(0deg)}75%{transform:translateY(-4px) rotate(-.2deg)}}
@keyframes npiPhoneEnter{0%{transform:translateY(50px) scale(.88);opacity:0}55%{transform:translateY(-6px) scale(1.03);opacity:1}75%{transform:translateY(3px) scale(.988)}100%{transform:translateY(0) scale(1);opacity:1}}
@keyframes npShadowPulse{0%,100%{opacity:1}50%{opacity:.6}}
@keyframes npDockEnter{to{opacity:1;transform:translateX(-50%) translateY(0)}}
@keyframes npHeroEnter{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes npFadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.np-fadein{animation:npFadeUp .30s cubic-bezier(.2,.85,.25,1) both}

/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   DESKTOP POLISH
â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */
@media(min-width:480px){
  .np-main{padding:0 20px}
  .np-sheet{max-width:430px;left:50%;right:auto}
  .np-sheet{transform:translateX(-50%) translateY(105%)}
  .np-sheet.open{transform:translateX(-50%) translateY(0)}
  /* Sticky pill – centred on desktop */
  .np-sticky-inner{margin:0 auto;max-width:430px}
  .np-headline{font-size:24px}}

/* Safe area */
@supports(padding-bottom:env(safe-area-inset-bottom)){
  .np-dock{bottom:calc(16px + env(safe-area-inset-bottom))}
  .np-sheet{padding-bottom:env(safe-area-inset-bottom)}}

/* Reduce motion */
@media(prefers-reduced-motion:reduce){
  .np-aurora,.np-amb,.np-topbar-live,.np-chip-dot,.np-confirmed-icon,.np-hero-img,.np-ticket-card,.np-ticket-inner::before{animation:none !important}
  .np-headline em{animation:none !important;background-position:0% 50%}
  .np-btn-cta,.np-btn-submit,.np-btn-cta.loading,.np-btn-submit.loading{animation:none !important}
  .np-btn-cta,.np-btn-submit,.np-btn-secondary,.np-btn-wa,.np-btn-share{transition:none !important}}

/* ══════════════════════════════════════════════════
   ULTRA POLISH ADDITIONS — 2026-05-27
   New elements from simplified checkout + check row
══════════════════════════════════════════════════ */

/* Check row — input + button inline */
.np-check-row{
  display:flex;gap:8px;align-items:stretch}
.np-check-row .np-form-input{
  flex:1;min-width:0;font-size:15px}
.np-btn-check{
  flex-shrink:0;padding:12px 20px;font-size:14px;
  border-radius:14px;white-space:nowrap;
  /* Kill the pan animation inside the check sheet */
  animation:none !important}

/* Sheet intro text */
.np-sheet-intro{
  font-size:14px;color:var(--ink3);margin-bottom:14px;line-height:1.5;margin-top:0}

/* Form hint text */
.np-form-hint{
  font-size:11px;color:var(--ink4);margin-top:5px;line-height:1.45;margin-bottom:0}

/* Form legal text */
.np-form-legal{
  font-size:11px;color:var(--ink4);text-align:center;margin-top:10px;line-height:1.5;margin-bottom:0}
.np-form-legal a{color:var(--blue-m);text-decoration:none;font-weight:600}

/* Wave checkout card — info column */
.np-co-wave-info{flex:1;min-width:0}
.np-co-wave-name{font-size:16px;font-weight:900;color:var(--ink)}
.np-co-wave-num{font-size:11px;font-weight:600;color:#00b4cc;margin-top:2px}

/* Pay row: logo-only, no text after */
.np-pay-row{
  margin-top:12px;padding:9px 20px;border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.58),rgba(255,255,255,.30));
  backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.72);
  box-shadow:var(--glass-hi2),var(--glass-sh2);
  display:flex;align-items:center;justify-content:center;gap:8px}
.np-pay-label{font-size:11px;font-weight:700;color:var(--ink4);letter-spacing:.03em}
.np-wave-inline-wrap{display:inline-flex;align-items:center;line-height:0;flex-shrink:0}
/* np-wave-inline defined above in pay row section */

/* Pack badge: neutral — D100 has no badge (defined hidden above) */

/* Subtle spacer at bottom of main */
.np-main::after{content:'';display:block;height:12px}

/* Topbar: tighten left gap for small screens */
@media(max-width:380px){
  .np-topbar-draw-badge{display:none}
  .np-topbar-logo{max-width:140px}
}

/* Check sheet: ensure button has min tap target */
.np-btn-check{min-height:46px}

/* Confirmed wrap spacing */
.np-confirmed-wrap{
  display:flex;flex-direction:column;align-items:center;
  gap:16px;text-align:center;padding-bottom:8px}
.np-confirmed-save{
  font-size:13px;color:var(--ink3);line-height:1.5;margin:0}
.np-you-are-in{
  font-size:11px;font-weight:900;letter-spacing:.14em;
  text-transform:uppercase;color:var(--green-b);margin-bottom:2px}
.np-confirmed-title{
  font-size:30px;font-weight:900;color:var(--ink);
  letter-spacing:-.04em;line-height:1.05}

/* ── REFERRAL CARD ──────────────────────────────────────────
   Shown after ticket confirmation. Subtle, premium, not pushy.
────────────────────────────────────────────────────────── */
/* ═══════════════════════════════════════════════
   CONFIRMED SCREEN — premium receipt hierarchy
   Check → Ticket → Referral → Actions
═══════════════════════════════════════════════ */
.np-confirmed-header{
  display:flex;align-items:center;gap:14px;width:100%;padding:2px 0}
.np-confirmed-check{
  width:44px;height:44px;border-radius:50%;flex-shrink:0;
  background:linear-gradient(135deg,rgba(52,211,153,.22),rgba(52,211,153,.06));
  border:2px solid rgba(52,211,153,.42);
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:900;color:#059669;
  box-shadow:0 0 0 6px rgba(52,211,153,.08)}
.np-you-are-in{
  font-size:22px;font-weight:900;color:var(--ink);
  letter-spacing:-.03em;line-height:1.1}
.np-confirmed-sub{
  font-size:13px;font-weight:600;color:var(--ink3);margin-top:2px}

/* Status link */
.np-confirmed-status-link{text-align:center;margin-top:-4px}
.np-status-link-a{
  font-size:12px;color:var(--blue-m);font-weight:600;
  text-decoration:none;opacity:.75}

/* Confirmed actions */
.np-confirmed-actions{display:flex;flex-direction:column;gap:9px;width:100%}
.np-save-wa{justify-content:center}
.np-buy-more{text-align:center;color:var(--ink3)}

/* Confirmed wrap */
.np-confirmed-wrap{display:flex;flex-direction:column;gap:16px;padding-bottom:8px}

/* ─── REFERRAL CARD — reward feel ──────────────────── */
.np-referral-card{
  width:100%;padding:16px;border-radius:18px;
  background:linear-gradient(160deg,rgba(222,236,255,.65),rgba(210,226,255,.42));
  border:1px solid rgba(90,161,255,.24);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.82)}
.np-referral-header{
  display:flex;align-items:center;justify-content:space-between;margin-bottom:5px}
.np-referral-title{
  font-size:15px;font-weight:900;color:var(--ink);letter-spacing:-.02em}
.np-referral-badge{
  font-size:10px;font-weight:900;color:var(--blue-m);
  background:rgba(90,161,255,.14);border:1px solid rgba(90,161,255,.28);
  padding:3px 8px;border-radius:999px;letter-spacing:.04em;white-space:nowrap}
.np-referral-sub{
  font-size:13px;font-weight:600;color:var(--ink3);
  line-height:1.45;margin-bottom:14px}
.np-referral-actions{display:flex;gap:8px;flex-wrap:wrap}
.np-referral-share{
  flex:1;justify-content:center;min-height:42px;animation:none !important}
.np-referral-copy{flex-shrink:0;min-height:42px;padding:11px 16px}
.np-referral-hint{
  font-size:11px;color:var(--ink4);margin-top:10px;
  line-height:1.4;text-align:left;margin-bottom:0}

/* ─── TICKET ID LAYOUTS ─────────────────────────────── */
/* 1 ticket — large single ID */
.np-ticket-ids-single{
  font-family:'Courier New',monospace;
  font-size:17px;font-weight:900;color:var(--ink);
  letter-spacing:.06em;line-height:1.4;padding:2px 0}
/* 2-3 tickets — compact vertical list */
.np-ticket-ids-list.multi .np-ticket-id-val{
  font-family:'Courier New',monospace;
  font-size:13px;font-weight:700;color:var(--ink);
  letter-spacing:.04em;padding:3px 0;
  border-bottom:1px solid rgba(72,110,178,.07)}
.np-ticket-ids-list.multi .np-ticket-id-val:last-child{border-bottom:none}
/* 4-12 tickets — 2-column compact grid */
.np-ticket-ids-grid{
  display:grid;grid-template-columns:1fr 1fr;
  gap:5px 8px;margin-top:4px}
.np-ticket-id-chip{
  font-family:'Courier New',monospace;
  font-size:11px;font-weight:700;color:var(--ink2);
  background:rgba(255,255,255,.72);
  border:1px solid rgba(72,110,178,.14);
  border-radius:8px;padding:5px 7px;
  letter-spacing:.02em;line-height:1.2;
  text-align:center;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.np-ticket-card.large .np-ticket-ids-area{padding:10px 0}

/* BEST CHANCE badge defined in pack section above */

/* ── PAY ROW — Wave only, logo only ────────────────── */
.np-pay-row{
  margin-top:12px;padding:9px 20px;border-radius:999px;
  background:linear-gradient(180deg,rgba(255,255,255,.60),rgba(255,255,255,.32));
  backdrop-filter:blur(14px);border:1px solid rgba(255,255,255,.72);
  box-shadow:var(--glass-hi2),var(--glass-sh2);
  display:flex;align-items:center;justify-content:center;gap:8px}
.np-pay-label{font-size:11px;font-weight:700;color:var(--ink4);letter-spacing:.03em}
.np-wave-inline-wrap{display:inline-flex;align-items:center;line-height:0;flex-shrink:0}
.np-wave-inline{height:20px;width:auto;object-fit:contain;display:block;opacity:.90}

/* ── OVERFLOW HARDENING ─────────────────────────────── */
html,body{overflow-x:hidden;width:100%}
*{box-sizing:border-box}
