/* ============================================================
   IGFOLLOWERS — v2 stylesheet
   Premium purple/violet build. Bricolage Grotesque + Inter.
   ============================================================ */

:root {
  --ink: #0c0a1a;
  --ink-2: #2a2640;
  --muted: #6f6b85;
  --line: #ece9f4;
  --bg: #ffffff;
  --bg-soft: #f6f4fc;
  --bg-deep: #0d0a1f;

  --purple: #7C3AED;
  --purple-d: #5b21b6;
  --indigo: #4F46E5;
  --violet: #A855F7;
  --glow: #C084FC;
  --cyan: #22D3EE;

  --soft-purple: #f2ecfe;
  --soft-indigo: #ecedff;
  --bg-tint: #f1ecfd;

  --grad: linear-gradient(135deg, #7C3AED 0%, #4F46E5 100%);
  --grad-bright: linear-gradient(120deg, #C084FC 0%, #A855F7 35%, #7C3AED 70%, #4F46E5 100%);

  --r-sm: 12px; --r: 18px; --r-lg: 26px; --r-xl: 34px;
  --sh-sm: 0 2px 8px rgba(20,12,50,0.06);
  --sh: 0 14px 40px rgba(76,29,149,0.12);
  --sh-lg: 0 30px 70px rgba(76,29,149,0.20);
  --sh-glow: 0 14px 40px rgba(124,58,237,0.35);
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--ink); background: var(--bg);
  line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, select, textarea { font-family: inherit; }

h1,h2,h3,h4 { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; letter-spacing: -0.025em; line-height: 1.08; }

.wrap { max-width: 1200px; margin: 0 auto; padding: 0 22px; }
.section { padding: 70px 0; }
@media (min-width: 768px) { .section { padding: 104px 0; } }
.center { text-align: center; }

/* ---------- Stacked-sheet sections (clear section boundaries) ---------- */
.sheet { position: relative; z-index: 1; border-radius: 38px 38px 0 0; margin-top: -38px; padding-top: 86px; }
@media (min-width: 768px) { .sheet { padding-top: 64px; } }
.bg-white { background: #fff; }
.bg-tint  { background: var(--bg-tint); }
.bg-dark  { background: var(--bg-deep); }
/* footer rounds over the last section too */
.footer.sheet { padding-top: 78px; }
@media (min-width: 768px) { .footer.sheet { padding-top: 98px; } }

.eyebrow {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 12px; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase;
  color: var(--purple); margin-bottom: 16px;
}
.eyebrow::before { content: ""; width: 22px; height: 2px; border-radius: 2px; background: var(--grad); }
.center .eyebrow::after { content: ""; width: 22px; height: 2px; border-radius: 2px; background: var(--grad); }
.h2 { font-size: clamp(32px, 5.2vw, 52px); color: var(--ink); margin-bottom: 16px; }
.lead { font-size: 17px; color: var(--muted); max-width: 600px; line-height: 1.65; }
.center .lead { margin-left: auto; margin-right: auto; }

/* scroll reveal */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity 0.7s cubic-bezier(.2,.7,.2,1), transform 0.7s cubic-bezier(.2,.7,.2,1); }
.reveal.in { opacity: 1; transform: none; }
.reveal.d1 { transition-delay: 0.08s; }
.reveal.d2 { transition-delay: 0.16s; }
.reveal.d3 { transition-delay: 0.24s; }
@media (prefers-reduced-motion: reduce) { .reveal { opacity: 1; transform: none; transition: none; } }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  padding: 15px 30px; border-radius: 999px; font-weight: 700; font-size: 15px;
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
  position: relative; white-space: nowrap;
}
.btn-primary { background: var(--grad); color: #fff; box-shadow: var(--sh-glow); }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 18px 44px rgba(124,58,237,0.45); }
.btn-ghost { background: #fff; color: var(--ink); border: 1.5px solid var(--line); }
.btn-ghost:hover { border-color: var(--purple); color: var(--purple); transform: translateY(-2px); }
.btn-light { background: rgba(255,255,255,0.12); color: #fff; border: 1px solid rgba(255,255,255,0.25); }
.btn-light:hover { background: rgba(255,255,255,0.2); }
.btn-lg { padding: 18px 38px; font-size: 16px; }
.btn-full { width: 100%; }
.btn:disabled { background: #e7e5f0; color: #a8a4bd; box-shadow: none; cursor: not-allowed; transform: none; }

/* ---------- Announcement (original) ---------- */
.announce {
  background: linear-gradient(95deg, #1E1B4B 0%, #312E81 50%, #4F46E5 100%);
  color: #fff; text-align: center;
  font-size: 13px; font-weight: 500; padding: 10px 16px;
}
.announce strong { font-weight: 800; }
.announce .pill { display: inline-block; background: var(--grad); padding: 3px 10px; border-radius: 999px; font-size: 11px; font-weight: 800; letter-spacing: 0.05em; margin-right: 9px; }

/* ---------- Header ---------- */
.header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(18px) saturate(160%); -webkit-backdrop-filter: blur(18px) saturate(160%);
  border-bottom: 1px solid var(--line);
}
.header-inner { display: flex; align-items: center; justify-content: space-between; height: 72px; }
.logo { display: flex; align-items: center; gap: 10px; font-family: 'Bricolage Grotesque', sans-serif; font-weight: 800; font-size: 22px; letter-spacing: -0.025em; color: var(--ink); }
.logo-mark { width: auto; height: 32px; background: transparent; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.logo-mark svg { width: 18px; height: 18px; color: var(--lime, #C3FF36); }
.logo-mark img { height: 100%; width: auto; display: block; }
.logo .tld { color: var(--lime, #C3FF36); font-weight: 800; }
.nav { display: none; gap: 32px; }
@media (min-width: 940px) { .nav { display: flex; } }
.nav a { font-size: 14px; font-weight: 600; color: var(--ink-2); position: relative; padding: 4px 0; }
.nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: 0; height: 2px; background: var(--grad); border-radius: 2px; transition: right .2s; }
.nav a:hover::after, .nav a.active::after { right: 0; }
.nav a:hover, .nav a.active { color: var(--purple); }
.header-actions { display: flex; align-items: center; gap: 10px; }
.header-cta {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 10px 18px;
  background: #0c0a1a; color: #fff;
  border-radius: 11px;
  font-size: 13.5px; font-weight: 700;
  text-decoration: none;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
  margin-right: 4px;
}
.header-cta:hover {
  background: #1d1437;
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(12,10,26,0.25);
}
@media (max-width: 768px) {
  .header-cta { display: none; }
}
.header .btn { display: none; }
@media (min-width: 940px) { .header .btn { display: inline-flex; padding: 11px 22px; font-size: 14px; } }
.cart-btn { position: relative; width: 44px; height: 44px; border-radius: 12px; background: var(--bg-soft); display: flex; align-items: center; justify-content: center; transition: background .15s; }
.cart-btn:hover { background: var(--soft-purple); }
.cart-btn svg { width: 19px; height: 19px; stroke: var(--ink); }
.cart-count { position: absolute; top: -5px; right: -5px; min-width: 19px; height: 19px; padding: 0 5px; background: var(--grad); color: #fff; border-radius: 999px; font-size: 11px; font-weight: 800; display: none; align-items: center; justify-content: center; box-shadow: 0 3px 8px rgba(124,58,237,0.5); }
.hamburger { display: flex; flex-direction: column; gap: 4px; width: 44px; height: 44px; border-radius: 12px; background: var(--bg-soft); align-items: center; justify-content: center; }
.hamburger span { width: 17px; height: 2px; background: var(--ink); border-radius: 2px; }
@media (min-width: 940px) { .hamburger { display: none; } }

/* ---------- Drawers ---------- */
.drawer-overlay, .cart-drawer-overlay { position: fixed; inset: 0; background: rgba(12,10,26,0.55); z-index: 200; opacity: 0; pointer-events: none; transition: opacity .25s; backdrop-filter: blur(4px); }
.drawer-overlay.open, .cart-drawer-overlay.open { opacity: 1; pointer-events: all; }
.drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 310px; max-width: 86vw; background: #fff; z-index: 210; transform: translateX(100%); transition: transform .3s cubic-bezier(.4,0,.2,1); display: flex; flex-direction: column; padding: 22px; }
.drawer.open { transform: translateX(0); }
.drawer-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 26px; }
.drawer-close { width: 40px; height: 40px; border-radius: 11px; background: var(--bg-soft); display: flex; align-items: center; justify-content: center; font-size: 21px; }
.drawer-links { display: flex; flex-direction: column; gap: 3px; }
.drawer-links a { padding: 14px; border-radius: 12px; font-weight: 600; font-size: 15px; }
.drawer-links a:hover { background: var(--soft-purple); color: var(--purple); }
.drawer-cta { margin-top: auto; }

/* ---------- Hero ---------- */
.hero { position: relative; overflow: hidden; padding: 72px 0 90px; background: var(--bg-soft); }
.hero-orb { position: absolute; border-radius: 50%; filter: blur(80px); pointer-events: none; }
.hero-orb.o1 { width: 460px; height: 460px; background: rgba(168,85,247,0.32); top: -160px; left: -120px; }
.hero-orb.o2 { width: 420px; height: 420px; background: rgba(79,70,229,0.28); bottom: -180px; right: -100px; }
.hero-orb.o3 { width: 300px; height: 300px; background: rgba(34,211,238,0.16); top: 40%; left: 55%; }
.hero-grid { position: relative; z-index: 1; display: grid; grid-template-columns: 1fr; gap: 48px; align-items: center; }
@media (min-width: 940px) { .hero-grid { grid-template-columns: 1.05fr 0.95fr; gap: 40px; } }
.hero-badge { display: inline-flex; align-items: center; gap: 8px; background: #fff; border: 1px solid var(--line); padding: 8px 15px; border-radius: 999px; font-size: 12px; font-weight: 700; color: var(--ink-2); box-shadow: var(--sh-sm); margin-bottom: 24px; }
.hero-badge .dot { width: 8px; height: 8px; border-radius: 50%; background: #10b981; box-shadow: 0 0 0 0 rgba(16,185,129,0.5); animation: pulse 2s infinite; }
@keyframes pulse { 0% { box-shadow: 0 0 0 0 rgba(16,185,129,0.5); } 70% { box-shadow: 0 0 0 9px rgba(16,185,129,0); } 100% { box-shadow: 0 0 0 0 rgba(16,185,129,0); } }
.hero-left h1 { font-size: clamp(40px, 6.6vw, 66px); margin-bottom: 18px; }
.hero-left h1 .grad { background: var(--grad-bright); -webkit-background-clip: text; background-clip: text; color: transparent; }
.hero-sub { font-size: 18px; color: var(--muted); max-width: 480px; margin-bottom: 26px; }
.hero-switch { display: grid; grid-template-columns: repeat(6, 1fr); gap: 4px; background: #fff; border: 1px solid var(--line); border-radius: 14px; padding: 5px; margin-bottom: 16px; box-shadow: var(--sh-sm); max-width: 720px; }
.hero-switch button { display: inline-flex; align-items: center; justify-content: center; gap: 6px; padding: 9px 14px; border-radius: 10px; font-size: 13px; font-weight: 700; color: var(--muted); transition: all .15s; }
.hero-switch button svg { display: inline-block; width: 14px; height: 14px; flex-shrink: 0; }
.hero-switch button.active { background: var(--grad); color: #fff; }
.hero-switch button[data-platform="instagram-followers"].active { background: linear-gradient(135deg,#833AB4,#E1306C,#F77737); }
.hero-switch button[data-platform="tiktok-followers"].active { background: #000; }
.hero-switch button[data-platform="spotify-streams"].active { background: #1DB954; }
.hero-switch button[data-platform="youtube-views"].active { background: #FF0000; }
.hero-switch button[data-platform="facebook-followers"].active { background: #1877F2; }
.hero-switch button[data-platform="x-twitter"].active { background: #000; }
.hero-switch button[data-platform="instagram-followers"]:not(.active) svg { color: #E1306C; }
.hero-switch button[data-platform="tiktok-followers"]:not(.active) svg { color: #000; }
.hero-switch button[data-platform="spotify-streams"]:not(.active) svg { color: #1DB954; }
.hero-switch button[data-platform="youtube-views"]:not(.active) svg { color: #FF0000; }
.hero-switch button[data-platform="facebook-followers"]:not(.active) svg { color: #1877F2; }
.hero-switch button[data-platform="x-twitter"]:not(.active) svg { color: #000; }
.hero-switch button.active svg { color: #fff; }
.hero-buys { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; max-width: 440px; margin-bottom: 24px; }
.hero-buy { display: flex; align-items: center; gap: 11px; background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 14px; text-align: left; transition: all .16s; }
.hero-buy:hover { border-color: var(--purple); transform: translateY(-2px); box-shadow: var(--sh); }
.hero-buy-ico { width: 38px; height: 38px; border-radius: 11px; background: var(--soft-purple); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.hero-buy-ico svg { width: 19px; height: 19px; stroke: var(--purple); }
.hero-buy-label { display: block; font-size: 12px; font-weight: 800; letter-spacing: 0.04em; }
.hero-buy-sub { display: block; margin-top: 2px; font-size: 11px; color: var(--muted); white-space: nowrap; }
.hero-buy-arrow { margin-left: auto; color: var(--purple); font-weight: 800; }
.hero-trust { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.hero-trust .avatars { display: flex; }
.hero-trust .avatars span { width: 32px; height: 32px; border-radius: 50%; border: 2px solid #fff; margin-left: -9px; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 800; font-size: 12px; }
.hero-trust .avatars span:nth-child(1){ background: #7C3AED; margin-left: 0; }
.hero-trust .avatars span:nth-child(2){ background: #A855F7; }
.hero-trust .avatars span:nth-child(3){ background: #4F46E5; }
.hero-trust .avatars span:nth-child(4){ background: #22D3EE; }
.hero-trust-text { font-size: 13px; color: var(--muted); }
.hero-trust-text strong { color: var(--ink); }
.hero-trust .stars { color: #f59e0b; letter-spacing: 1px; }

/* hero visual */
.hero-visual { position: relative; min-height: 380px; }
.hv-card {
  background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg);
  box-shadow: var(--sh-lg); padding: 22px; max-width: 420px; margin: 0 auto;
  position: relative; z-index: 2;
}
.hv-profile { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.hv-avatar { width: 52px; height: 52px; border-radius: 50%; background: var(--grad-bright); padding: 3px; }
.hv-avatar div { width: 100%; height: 100%; border-radius: 50%; background: #fff; display: flex; align-items: center; justify-content: center; font-weight: 800; color: var(--purple); font-size: 18px; }
.hv-name { font-weight: 800; font-size: 15px; }
.hv-handle { font-size: 12px; color: var(--muted); }
.hv-stats { display: grid; grid-template-columns: repeat(3,1fr); gap: 6px; margin-bottom: 16px; text-align: center; }
.hv-stat-n { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: 17px; }
.hv-stat-l { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.05em; }
.hv-chart { background: var(--bg-soft); border-radius: 14px; padding: 14px; }
.hv-chart-top { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 8px; }
.hv-chart-l { font-size: 10px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.05em; font-weight: 700; }
.hv-chart-v { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: 20px; color: var(--purple); }
.hv-chart-v small { color: #10b981; font-size: 12px; font-weight: 800; }
.hv-chart svg { width: 100%; height: 70px; display: block; }
.hv-float {
  position: absolute; background: #fff; border: 1px solid var(--line);
  border-radius: 14px; padding: 10px 14px; box-shadow: var(--sh);
  font-size: 12px; font-weight: 700; display: flex; align-items: center; gap: 8px; z-index: 3;
}
.hv-float .ic { width: 26px; height: 26px; border-radius: 8px; display: flex; align-items: center; justify-content: center; color: #fff; flex-shrink: 0; }
.hv-float.f1 { top: -40px; left: 18px; animation: floaty 4s ease-in-out infinite; }
.hv-float.f2 { bottom: 60px; right: -16px; animation: floaty 4s ease-in-out infinite 1.3s; }
.hv-float.f3 { bottom: -14px; left: 24px; animation: floaty 4s ease-in-out infinite 2.4s; }
@keyframes floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-9px); } }
@media (max-width: 939px) { .hv-float.f1 { left: 2%; } .hv-float.f2 { right: 2%; } }
@media (max-width: 560px) {
  .hero { padding-top: 24px; padding-bottom: 72px; }
  .sheet { padding-top: 48px; }
  .hero-buys { grid-template-columns: 1fr; }
  .hero-visual { min-height: auto; }
  .hv-float { display: none; }
  .hero-left h1 { font-size: 34px; }
  .hero-sub { font-size: 15px; margin-bottom: 22px; }
  .hero-switch { grid-template-columns: repeat(3, 1fr); max-width: none; }
  .announce-extra { display: none; }
  .announce { white-space: nowrap; }
  .hero .trust-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 10px; justify-items: start; }
  .hero .trust-item { font-size: 12px; gap: 6px; align-items: flex-start; white-space: nowrap; }
  .hero .trust-item svg { width: 16px; height: 16px; }
  .hero .trust-pay { flex-direction: row; align-items: center; gap: 6px; }
  .hero .trust-pay .trust-pay-label { display: none; }
  .hero .pay-badges { gap: 3px; }
  .hero .pay-badges .pay { height: 16px; min-width: 22px; padding: 0 3px; font-size: 8px; }
  .hero .pay-badges .pay-mc i { width: 8px; height: 8px; }
  .pay-badges .pay-mc i { width: 9px; height: 9px; }
}

/* ---------- Trust row ---------- */
.hero .trust-row { margin-top: 52px; padding-top: 28px; border-top: 1px solid rgba(124,58,237,0.14); position: relative; z-index: 1; }
.trust-row { display: flex; align-items: center; justify-content: center; gap: 14px 30px; flex-wrap: wrap; }
.trust-item { display: flex; align-items: center; gap: 8px; font-size: 13px; font-weight: 700; color: var(--ink-2); }
.trust-item svg { width: 18px; height: 18px; stroke: var(--purple); }
.trust-sep { width: 1px; height: 18px; background: var(--line); }
@media (max-width: 640px) { .trust-sep { display: none; } }
.pay-badges { display: flex; gap: 5px; align-items: center; }
.pay-badges .pay { display: inline-flex; align-items: center; justify-content: center; height: 18px; min-width: 30px; padding: 0 6px; border-radius: 4px; font-size: 9px; font-weight: 800; letter-spacing: 0.04em; }
.pay-badges .pay-visa { background: #1A1F71; color: #fff; font-style: italic; }
.pay-badges .pay-mc { background: #fff; border: 1px solid var(--line); padding: 0 4px; gap: 0; min-width: 30px; }
.pay-badges .pay-mc i { width: 11px; height: 11px; border-radius: 50%; display: block; }
.pay-badges .pay-mc i:first-child { background: #EB001B; margin-right: -4px; }
.pay-badges .pay-mc i:last-child { background: #F79E1B; opacity: 0.85; }
.pay-badges .pay-amex { background: #2557D6; color: #fff; }
.pay-badges .pay-applepay { background: #000; color: #fff; font-style: normal; letter-spacing: 0; }

/* ---------- Stats ---------- */
.stats-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 16px; margin-top: 48px; }
@media (min-width: 760px) { .stats-grid { grid-template-columns: repeat(4,1fr); } }
.stat-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 30px 18px; text-align: center; transition: transform .2s, box-shadow .2s; }
.stat-card:hover { transform: translateY(-4px); box-shadow: var(--sh); }
.stat-ico { width: 46px; height: 46px; border-radius: 13px; background: var(--soft-purple); display: flex; align-items: center; justify-content: center; margin: 0 auto 14px; }
.stat-ico svg { width: 22px; height: 22px; stroke: var(--purple); }
.stat-num { font-family: 'Bricolage Grotesque', sans-serif; font-size: 34px; font-weight: 700; color: var(--ink); }
.stat-lbl { font-size: 12px; font-weight: 600; color: var(--muted); text-transform: uppercase; letter-spacing: 0.07em; margin-top: 4px; }

/* ---------- Platform picker ---------- */
.pp-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 14px; margin-top: 46px; }
@media (min-width: 640px) { .pp-grid { grid-template-columns: repeat(3,1fr); } }
@media (min-width: 960px) { .pp-grid { grid-template-columns: repeat(6,1fr); } }
.pp-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r); padding: 24px 12px; text-align: center; transition: all .18s; }
.pp-card:hover { border-color: var(--purple); transform: translateY(-5px); box-shadow: var(--sh); }
.pp-ico { width: 48px; height: 48px; border-radius: 14px; margin: 0 auto 12px; display: flex; align-items: center; justify-content: center; }
.pp-ico svg { width: 24px; height: 24px; }
.pp-name { font-size: 14px; font-weight: 700; }
.pp-from { font-size: 12px; color: var(--muted); }

/* ---------- Showcase ---------- */
.showcase-tabs { display: flex; gap: 7px; justify-content: center; flex-wrap: wrap; margin: 40px 0 44px; }
.showcase-tab { padding: 11px 20px; border-radius: 999px; font-size: 13px; font-weight: 700; background: #fff; border: 1px solid var(--line); color: var(--muted); transition: all .15s; }
.showcase-tab.active { background: var(--grad); color: #fff; border-color: transparent; box-shadow: var(--sh-glow); }
.showcase-panel { display: none; }
.showcase-panel.active { display: grid; grid-template-columns: 1fr; gap: 38px; align-items: center; }
@media (min-width: 900px) { .showcase-panel.active { grid-template-columns: 1.05fr 0.95fr; gap: 60px; } }
.showcase-h { font-size: clamp(27px, 4vw, 38px); margin-bottom: 14px; }
.showcase-p { color: var(--muted); margin-bottom: 24px; }
.showcase-checks { list-style: none; display: flex; flex-direction: column; gap: 12px; margin-bottom: 28px; }
.showcase-checks li { display: flex; gap: 12px; align-items: flex-start; font-size: 14px; font-weight: 500; color: var(--ink-2); }
.showcase-checks .tick { width: 24px; height: 24px; border-radius: 8px; background: var(--grad); color: #fff; font-weight: 900; font-size: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.showcase-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-xl); padding: 26px; box-shadow: var(--sh); }
.showcase-card-head { display: flex; align-items: center; justify-content: space-between; padding-bottom: 14px; border-bottom: 1px solid var(--line); margin-bottom: 6px; }
.showcase-card-head h4 { font-size: 15px; }
.showcase-card-head .badge { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; background: var(--soft-purple); color: var(--purple); padding: 4px 10px; border-radius: 999px; }
.pkg-row { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; border-bottom: 1px dashed var(--line); }
.pkg-row:last-of-type { border-bottom: none; }
.pkg-qty { font-size: 15px; font-weight: 700; }
.pkg-qty small { display: block; font-size: 11px; font-weight: 500; color: var(--muted); }
.pkg-price { font-family: 'Bricolage Grotesque', sans-serif; font-size: 17px; font-weight: 700; }
.pkg-price small { font-size: 11px; color: var(--muted); text-decoration: line-through; margin-right: 5px; font-weight: 500; font-family: 'Inter'; }
.showcase-see { display: block; text-align: center; margin-top: 16px; padding-top: 16px; border-top: 1px solid var(--line); font-size: 13px; font-weight: 700; color: var(--purple); }

/* ---------- Growth Estimator (unique feature) ---------- */
.estimator { position: relative; overflow: hidden; background: var(--bg-deep); color: #fff; }
.estimator .hero-orb.o1 { background: rgba(168,85,247,0.4); top: -200px; left: -100px; }
.estimator .hero-orb.o2 { background: rgba(79,70,229,0.4); bottom: -200px; right: -100px; }
.estimator .eyebrow { color: var(--glow); }
.estimator .eyebrow::before, .estimator .center .eyebrow::after { background: var(--glow); }
.estimator .h2 { color: #fff; }
.estimator .lead { color: rgba(255,255,255,0.6); }
.est-box {
  position: relative; z-index: 1; max-width: 720px; margin: 44px auto 0;
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--r-xl); padding: 32px; backdrop-filter: blur(12px);
}
.est-row { margin-bottom: 26px; }
.est-label { font-size: 13px; font-weight: 700; color: rgba(255,255,255,0.7); margin-bottom: 12px; display: flex; justify-content: space-between; }
.est-platforms { display: flex; flex-wrap: wrap; gap: 8px; }
.est-platforms button {
  padding: 9px 16px; border-radius: 999px; font-size: 13px; font-weight: 700;
  background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.75);
  border: 1px solid rgba(255,255,255,0.12); transition: all .15s;
}
.est-platforms button.active { background: #fff; color: var(--ink); border-color: #fff; }
.est-slider { width: 100%; -webkit-appearance: none; appearance: none; height: 8px; border-radius: 999px; background: rgba(255,255,255,0.15); outline: none; }
.est-slider::-webkit-slider-thumb { -webkit-appearance: none; width: 26px; height: 26px; border-radius: 50%; background: #fff; cursor: pointer; box-shadow: 0 4px 14px rgba(0,0,0,0.4); border: 4px solid var(--violet); }
.est-slider::-moz-range-thumb { width: 22px; height: 22px; border-radius: 50%; background: #fff; cursor: pointer; border: 4px solid var(--violet); }
.est-goal { font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; color: var(--glow); }
.est-result { display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.12); border-radius: var(--r); padding: 20px 22px; margin-top: 6px; }
.est-result-label { font-size: 12px; color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 700; }
.est-result-pkg { font-family: 'Bricolage Grotesque', sans-serif; font-size: 22px; font-weight: 700; }
.est-result-price { font-family: 'Bricolage Grotesque', sans-serif; font-size: 30px; font-weight: 700; color: var(--glow); }

/* ---------- How it works ---------- */
.hiw-grid { display: grid; grid-template-columns: 1fr; gap: 22px; margin-top: 54px; position: relative; }
@media (min-width: 780px) {
  .hiw-grid { grid-template-columns: repeat(3,1fr); gap: 26px; }
  .hiw-grid::before { content: ""; position: absolute; top: 60px; left: 17%; right: 17%; height: 2px; z-index: 0; background: repeating-linear-gradient(90deg, var(--line) 0 7px, transparent 7px 15px); }
}
.hiw-card { position: relative; z-index: 1; background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 32px 26px; text-align: center; transition: transform .2s, box-shadow .2s; }
.hiw-card:hover { transform: translateY(-5px); box-shadow: var(--sh); }
.hiw-num { position: relative; width: 64px; height: 64px; border-radius: 20px; margin: 0 auto 18px; background: var(--grad); display: flex; align-items: center; justify-content: center; box-shadow: var(--sh-glow); }
.hiw-num svg { width: 28px; height: 28px; stroke: #fff; fill: none; }
.hiw-num span { position: absolute; top: -8px; right: -8px; width: 26px; height: 26px; border-radius: 50%; background: #fff; border: 2px solid var(--purple); color: var(--purple); font-family: 'Bricolage Grotesque', sans-serif; font-weight: 700; font-size: 13px; display: flex; align-items: center; justify-content: center; }
.hiw-step { font-size: 11px; font-weight: 800; letter-spacing: 0.13em; text-transform: uppercase; color: var(--purple); margin-bottom: 8px; }
.hiw-h { font-size: 20px; margin-bottom: 8px; }
.hiw-p { font-size: 14px; color: var(--muted); }

/* ---------- Bento (why us) ---------- */
.bento { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: 50px; }
@media (min-width: 760px) { .bento { grid-template-columns: repeat(6,1fr); grid-auto-rows: 1fr; } }
.bento-card { border-radius: var(--r-lg); padding: 28px; border: 1px solid var(--line); background: #fff; display: flex; flex-direction: column; transition: transform .2s, box-shadow .2s; }
.bento-card:hover { transform: translateY(-4px); box-shadow: var(--sh); }
.b-wide { grid-column: span 6; }
@media (min-width: 760px) { .b-4 { grid-column: span 4; } .b-3 { grid-column: span 3; } .b-2 { grid-column: span 2; } }
.bento-card.feature { background: var(--grad); color: #fff; border-color: transparent; }
.bento-card.dark { background: var(--bg-deep); color: #fff; border-color: transparent; }
.bento-ico { width: 48px; height: 48px; border-radius: 14px; background: var(--soft-purple); display: flex; align-items: center; justify-content: center; margin-bottom: 16px; }
.bento-ico svg { width: 23px; height: 23px; stroke: var(--purple); }
.bento-card.feature .bento-ico, .bento-card.dark .bento-ico { background: rgba(255,255,255,0.16); }
.bento-card.feature .bento-ico svg, .bento-card.dark .bento-ico svg { stroke: #fff; }
.bento-stat { font-family: 'Bricolage Grotesque', sans-serif; font-size: 44px; font-weight: 700; line-height: 1; margin-bottom: 6px; }
.bento-h { font-size: 19px; font-weight: 700; font-family: 'Bricolage Grotesque', sans-serif; margin-bottom: 7px; }
.bento-p { font-size: 14px; color: var(--muted); }
.bento-card.feature .bento-p, .bento-card.dark .bento-p { color: rgba(255,255,255,0.72); }
.bento-card.feature .bento-h, .bento-card.dark .bento-h { color: #fff; }

/* ---------- Activity feed (unique) ---------- */
.activity { background: var(--bg-soft); }
.activity-wrap { display: grid; grid-template-columns: 1fr; gap: 40px; align-items: center; margin-top: 44px; }
@media (min-width: 880px) { .activity-wrap { grid-template-columns: 0.9fr 1.1fr; gap: 56px; } }
.activity-feed { background: #fff; border: 1px solid var(--line); border-radius: var(--r-xl); padding: 12px; box-shadow: var(--sh); }
.activity-head { display: flex; align-items: center; justify-content: space-between; padding: 12px 14px; border-bottom: 1px solid var(--line); margin-bottom: 6px; }
.activity-title { font-size: 13px; font-weight: 800; display: flex; align-items: center; gap: 8px; }
.activity-live { font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em; color: #10b981; background: #ecfdf5; padding: 3px 9px; border-radius: 999px; }
.activity-item { display: flex; align-items: center; gap: 12px; padding: 13px 14px; border-radius: 12px; transition: background .2s; }
.activity-item + .activity-item { border-top: 1px dashed var(--line); }
.activity-ico { width: 38px; height: 38px; border-radius: 11px; display: flex; align-items: center; justify-content: center; color: #fff; flex-shrink: 0; }
.activity-ico svg { width: 18px; height: 18px; }
.activity-body { flex: 1; min-width: 0; }
.activity-name { font-size: 13px; font-weight: 700; }
.activity-what { font-size: 12px; color: var(--muted); }
.activity-what strong { color: var(--ink-2); }
.activity-time { font-size: 11px; color: #a8a4bd; font-weight: 600; white-space: nowrap; }

/* ---------- Testimonials ---------- */
.rv-grid { display: grid; grid-template-columns: 1fr; gap: 18px; margin-top: 46px; }
@media (min-width: 680px) { .rv-grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1000px) { .rv-grid { grid-template-columns: repeat(3,1fr); } }
.rv { position: relative; background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: 28px; overflow: hidden; transition: transform .2s, box-shadow .2s, border-color .2s; }
.rv::before { content: "\201C"; position: absolute; top: 6px; right: 20px; font-family: 'Bricolage Grotesque', sans-serif; font-size: 80px; line-height: 1; color: var(--soft-purple); font-weight: 700; }
.rv::after { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px; background: var(--grad); transform: scaleX(0); transform-origin: left; transition: transform .25s; }
.rv:hover { transform: translateY(-5px); box-shadow: var(--sh); border-color: #ddd6f3; }
.rv:hover::after { transform: scaleX(1); }
.rv-stars { position: relative; color: #f59e0b; font-size: 14px; letter-spacing: 2px; margin-bottom: 12px; }
.rv-title { font-weight: 700; font-size: 15px; font-family: 'Bricolage Grotesque', sans-serif; margin-bottom: 7px; }
.rv-body { font-size: 14px; color: var(--muted); margin-bottom: 18px; }
.rv-foot { display: flex; align-items: center; gap: 11px; }
.rv-av { width: 38px; height: 38px; border-radius: 50%; background: var(--grad); color: #fff; font-weight: 800; font-size: 14px; display: flex; align-items: center; justify-content: center; }
.rv-name { font-size: 13px; font-weight: 700; }
.rv-time { font-size: 11px; color: var(--muted); }
.rv-badge { margin-left: auto; font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: #16a34a; background: #f0fdf4; padding: 3px 9px; border-radius: 999px; }

/* ---------- FAQ ---------- */
.faq-list { max-width: 780px; margin: 46px auto 0; }
.faq-item { border: 1px solid var(--line); border-radius: var(--r); margin-bottom: 10px; background: #fff; transition: border-color .15s; }
.faq-item.open { border-color: var(--purple); }
.faq-q { width: 100%; text-align: left; padding: 20px 22px; font-family: 'Bricolage Grotesque', sans-serif; font-size: 16px; font-weight: 600; display: flex; justify-content: space-between; align-items: center; gap: 16px; }
.faq-q::after { content: "+"; color: var(--purple); font-size: 24px; font-weight: 400; flex-shrink: 0; transition: transform .2s; }
.faq-item.open .faq-q::after { content: "\2212"; }
.faq-a { font-size: 15px; color: var(--muted); line-height: 1.7; padding: 0 22px 20px; display: none; }
.faq-item.open .faq-a { display: block; }

/* ---------- Final CTA ---------- */
.final-cta { position: relative; overflow: hidden; text-align: center; padding: 100px 0; background: var(--bg-deep); }
.final-cta .hero-orb.o1 { background: rgba(168,85,247,0.4); top: -160px; left: 10%; }
.final-cta .hero-orb.o2 { background: rgba(79,70,229,0.4); bottom: -160px; right: 10%; }
.final-cta-inner { position: relative; z-index: 1; }
.final-cta h2 { color: #fff; font-size: clamp(34px, 6vw, 58px); margin-bottom: 16px; }
.final-cta h2 .grad { background: linear-gradient(120deg, #C084FC, #A855F7); -webkit-background-clip: text; background-clip: text; color: transparent; }
.final-cta p { color: rgba(255,255,255,0.65); font-size: 17px; max-width: 500px; margin: 0 auto 30px; }
.final-cta-trust { display: flex; gap: 8px; justify-content: center; flex-wrap: wrap; margin-top: 26px; }
.final-cta-trust span { font-size: 12px; font-weight: 600; color: rgba(255,255,255,0.7); background: rgba(255,255,255,0.08); border: 1px solid rgba(255,255,255,0.14); padding: 7px 14px; border-radius: 999px; }

/* ---------- Footer ---------- */
.footer { background: var(--bg-soft); border-top: 1px solid var(--line); padding: 60px 0 32px; }
.footer-top { display: grid; grid-template-columns: 1fr; gap: 34px; margin-bottom: 44px; }
@media (min-width: 760px) { .footer-top { grid-template-columns: 1.7fr 1fr 1fr 1fr; gap: 44px; } }
.footer-brand p { font-size: 13px; color: var(--muted); max-width: 250px; margin-top: 13px; }
.footer-social { display: flex; gap: 9px; margin-top: 16px; }
.footer-social a { width: 36px; height: 36px; border-radius: 10px; background: #fff; border: 1px solid var(--line); display: flex; align-items: center; justify-content: center; transition: all .15s; }
.footer-social a:hover { background: var(--purple); border-color: var(--purple); }
.footer-social a:hover svg { fill: #fff; }
.footer-social svg { width: 16px; height: 16px; fill: var(--ink-2); }
.footer-col h4 { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); margin-bottom: 15px; }
.footer-col a { display: block; font-size: 14px; color: var(--ink-2); margin-bottom: 10px; }
.footer-col a:hover { color: var(--purple); }
.footer-bottom { border-top: 1px solid var(--line); padding-top: 24px; display: flex; justify-content: space-between; gap: 14px; flex-wrap: wrap; font-size: 13px; color: var(--muted); }

/* ---------- Cart drawer ---------- */
.cart-drawer { position: fixed; top: 0; right: 0; bottom: 0; width: 410px; max-width: 93vw; background: #fff; z-index: 230; transform: translateX(100%); transition: transform .3s cubic-bezier(.4,0,.2,1); display: flex; flex-direction: column; }
.cart-drawer.open { transform: translateX(0); }
.cart-head { display: flex; align-items: center; justify-content: space-between; padding: 20px; border-bottom: 1px solid var(--line); }
.cart-head h3 { font-size: 18px; }
.cart-goal { padding: 14px 20px; border-bottom: 1px solid var(--line); }
.cart-goal[hidden] { display: none; }
.cart-goal-text { font-size: 12px; font-weight: 700; }
.cart-goal-text strong { color: var(--purple); }
.cart-goal.done .cart-goal-text strong { color: #10b981; }
.cart-goal-track { height: 8px; background: var(--bg-soft); border-radius: 999px; overflow: hidden; margin-top: 8px; }
.cart-goal-fill { height: 100%; width: 0; border-radius: 999px; background: var(--grad); transition: width .35s ease; }
.cart-goal.done .cart-goal-fill { background: linear-gradient(90deg,#10b981,#34d399); }
.cart-items { flex: 1; overflow-y: auto; padding: 14px 20px; }
.cart-empty { text-align: center; padding: 60px 20px; color: var(--muted); }
.cart-empty svg { width: 48px; height: 48px; stroke: #d8d4e6; margin: 0 auto 14px; }
.cart-item { display: flex; gap: 12px; padding: 14px 0; border-bottom: 1px solid var(--line); }
.cart-item-ico { width: 46px; height: 46px; border-radius: 12px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; }
.cart-item-ico svg { width: 22px; height: 22px; }
.cart-item-info { flex: 1; min-width: 0; }
.cart-item-title { font-size: 14px; font-weight: 700; }
.cart-item-meta { font-size: 12px; color: var(--muted); word-break: break-all; }
.cart-item-price { font-size: 14px; font-weight: 800; margin-top: 3px; }
.cart-item-remove { color: #a8a4bd; font-size: 20px; align-self: flex-start; }
.cart-item-remove:hover { color: #dc2626; }
.cart-foot { padding: 20px; border-top: 1px solid var(--line); }
.cart-subtotal { display: flex; justify-content: space-between; font-weight: 800; font-size: 18px; margin-bottom: 14px; }
.cart-note { text-align: center; font-size: 12px; color: var(--muted); margin-top: 10px; }

/* ---------- Product page ---------- */
.pdp { padding: 36px 0 80px; }
.pdp-crumb { font-size: 13px; color: var(--muted); margin-bottom: 20px; }
.pdp-crumb a:hover { color: var(--purple); }
.pdp-grid { display: grid; grid-template-columns: 1fr; gap: 38px; }
@media (min-width: 980px) { .pdp-grid { grid-template-columns: 1fr 374px; gap: 46px; align-items: start; } }
.pdp h1 { font-size: clamp(26px, 4.6vw, 42px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.05; }
.pdp-hero { display: flex; align-items: center; gap: 16px; margin-bottom: 16px; }
.pdp .hero-buy-ico { width: 56px; height: 56px; border-radius: 14px; flex-shrink: 0; }
.pdp .hero-buy-ico svg { width: 28px; height: 28px; }
.pdp-desc { color: var(--muted); margin-bottom: 18px; font-size: 16px; line-height: 1.55; }
.pdp-trust-row { display: flex; align-items: center; gap: 14px; padding: 12px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); margin-bottom: 22px; flex-wrap: wrap; }
.pdp-trust-item { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--muted); }
.pdp-trust-item strong { color: var(--ink); font-weight: 800; }
.pdp-stars { color: #f59e0b; letter-spacing: 1px; font-size: 12px; }
.pdp-trust-sep { width: 1px; height: 16px; background: var(--line); }
.pdp-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 26px; }
.pdp-chip { display: inline-flex; align-items: center; gap: 6px; background: #f0fdf4; border: 1px solid #bbf7d0; color: #16a34a; font-size: 12px; font-weight: 700; padding: 7px 13px; border-radius: 999px; }
@media (max-width: 560px) {
  .pdp { padding: 22px 0 60px; }
  .pdp h1 { font-size: 24px; }
  .pdp-desc { font-size: 14px; margin-bottom: 14px; }
  .pdp .hero-buy-ico { width: 46px; height: 46px; }
  .pdp .hero-buy-ico svg { width: 23px; height: 23px; }
  .pdp-trust-row { gap: 10px; padding: 10px 0; }
  .pdp-trust-item { font-size: 12px; }
}
.pdp-tabs { display: inline-flex; gap: 4px; background: var(--bg-soft); border: 1px solid var(--line); border-radius: 13px; padding: 4px; margin-bottom: 22px; }
.pdp-tab { padding: 9px 19px; border-radius: 10px; font-size: 13px; font-weight: 700; color: var(--muted); transition: all .15s; }
.pdp-tab.active { background: #fff; color: var(--purple); box-shadow: var(--sh-sm); }
.pdp-pkg-label { font-size: 12px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); margin-bottom: 14px; }
.pkg-card { border: 2px solid var(--line); border-radius: var(--r); padding: 18px; margin-bottom: 11px; cursor: pointer; transition: all .16s; background: #fff; position: relative; }
.pkg-card:hover { border-color: var(--purple); }
.pkg-card.selected { border-color: var(--purple); background: var(--soft-purple); }
.pkg-card-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.pkg-card-qty { font-family: 'Bricolage Grotesque', sans-serif; font-size: 25px; font-weight: 700; }
.pkg-card-qty span { font-size: 13px; color: var(--muted); font-weight: 600; margin-left: 4px; }
.pkg-card-price { font-family: 'Bricolage Grotesque', sans-serif; font-size: 23px; font-weight: 700; text-align: right; }
.pkg-card-price small { display: block; font-family: 'Inter', sans-serif; font-size: 12px; font-weight: 500; color: var(--muted); text-decoration: line-through; margin-bottom: 1px; }
.pkg-card.selected .pkg-card-price { color: var(--purple); }
.pkg-card-feats { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 12px; }
.pkg-card-feat { font-size: 10px; font-weight: 700; color: var(--muted); background: var(--bg-soft); border-radius: 999px; padding: 3px 9px; }
.pkg-card-save { font-size: 10px; font-weight: 800; color: #16a34a; background: #f0fdf4; border: 1px solid #bbf7d0; border-radius: 999px; padding: 3px 9px; letter-spacing: 0.04em; }
.pkg-card.selected .pkg-card-feat { background: #fff; color: var(--purple); }
.pkg-card-btn { width: 100%; padding: 11px; border-radius: 11px; font-size: 13px; font-weight: 700; border: 2px solid var(--purple); color: var(--purple); background: transparent; }
.pkg-card.selected .pkg-card-btn { background: var(--purple); color: #fff; }
.pkg-badge { position: absolute; top: -10px; left: 16px; font-size: 9px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.08em; background: var(--grad); color: #fff; padding: 3px 10px; border-radius: 999px; }
.summary { background: #fff; border: 1px solid var(--line); border-radius: var(--r-xl); padding: 24px; box-shadow: var(--sh); }
@media (min-width: 980px) { .summary { position: sticky; top: 92px; } }
.summary-title { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.1em; color: var(--muted); padding-bottom: 13px; border-bottom: 1px solid var(--line); margin-bottom: 14px; }
.summary-label { font-size: 12px; color: var(--muted); font-weight: 600; }
.summary-pkg { font-family: 'Bricolage Grotesque', sans-serif; font-size: 21px; font-weight: 700; margin-bottom: 14px; }
.uname-wrap { position: relative; margin-bottom: 6px; }
.uname-shell { display: flex; align-items: center; background: #fff; border: 1.5px solid var(--line); border-radius: 12px; overflow: hidden; transition: border-color .15s; }
.uname-shell:focus-within { border-color: var(--purple); }
.uname-shell.bad { border-color: #dc2626; background: #fef2f2; }
.uname-prefix { padding: 12px 0 12px 13px; font-size: 13px; color: var(--muted); font-family: ui-monospace, Menlo, monospace; white-space: nowrap; user-select: none; }
.uname-shell input { flex: 1; min-width: 0; padding: 12px 38px 12px 2px; border: none; outline: none; background: transparent; font-size: 16px; font-family: ui-monospace, Menlo, monospace; }
.uname-err { font-size: 11px; font-weight: 600; color: #dc2626; margin: 6px 2px 0; min-height: 14px; }
.summary-cta { width: 100%; margin-top: 8px; }
.summary-note { text-align: center; font-size: 12px; color: var(--muted); margin-top: 12px; }

/* ---------- Sub-pages ---------- */
.page-hero { position: relative; overflow: hidden; background: var(--bg-soft); padding: 70px 0; text-align: center; border-bottom: 1px solid var(--line); }
.page-hero h1 { font-size: clamp(34px,5vw,52px); margin-bottom: 12px; position: relative; z-index: 1; }
.page-hero p { color: var(--muted); max-width: 540px; margin: 0 auto; position: relative; z-index: 1; }
.prose { max-width: 730px; margin: 0 auto; }
.prose h2 { font-size: 27px; margin: 36px 0 12px; }
.prose h3 { font-size: 19px; margin: 26px 0 8px; }
.prose p { color: var(--ink-2); margin-bottom: 14px; }
.prose ul { margin: 0 0 14px 20px; color: var(--ink-2); }
.prose li { margin-bottom: 7px; }
.form-grid { max-width: 560px; margin: 0 auto; display: flex; flex-direction: column; gap: 16px; }
.field label { display: block; font-size: 13px; font-weight: 700; margin-bottom: 6px; }
.field input, .field textarea, .field select { width: 100%; padding: 13px 15px; border: 1.5px solid var(--line); border-radius: 12px; font-size: 15px; outline: none; transition: border-color .15s; }
.field input:focus, .field textarea:focus, .field select:focus { border-color: var(--purple); }
.field textarea { resize: vertical; min-height: 130px; }
.blog-grid { display: grid; grid-template-columns: 1fr; gap: 22px; }
@media (min-width: 680px) { .blog-grid { grid-template-columns: repeat(2,1fr); } }
@media (min-width: 980px) { .blog-grid { grid-template-columns: repeat(3,1fr); } }
.blog-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; transition: all .18s; }
.blog-card:hover { transform: translateY(-4px); box-shadow: var(--sh); border-color: var(--purple); }
.blog-card-img { height: 168px; background: var(--grad-bright); display: flex; align-items: center; justify-content: center; }
.blog-card-img svg { width: 42px; height: 42px; stroke: rgba(255,255,255,0.85); }
.blog-card-body { padding: 22px; }
.blog-card-tag { font-size: 11px; font-weight: 800; text-transform: uppercase; letter-spacing: 0.06em; color: var(--purple); }
.blog-card-title { font-size: 17px; font-weight: 700; font-family: 'Bricolage Grotesque', sans-serif; margin: 7px 0; }
.blog-card-excerpt { font-size: 13px; color: var(--muted); }

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta {
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 90;
  background: rgba(255,255,255,0.96); backdrop-filter: blur(14px);
  border-top: 1px solid var(--line); padding: 12px 16px calc(12px + env(safe-area-inset-bottom));
  display: flex; align-items: center; gap: 12px;
  transform: translateY(110%); transition: transform .3s ease;
  box-shadow: 0 -8px 30px rgba(20,12,50,0.10);
}
.sticky-cta.show { transform: translateY(0); }
.sticky-cta-text { flex: 1; min-width: 0; }
.sticky-cta-text strong { display: block; font-size: 14px; font-weight: 800; }
.sticky-cta-text span { font-size: 12px; color: var(--muted); }
.sticky-cta .btn { padding: 13px 22px; }
@media (min-width: 768px) { .sticky-cta { display: none; } }
@media (max-width: 767px) { body { padding-bottom: calc(84px + env(safe-area-inset-bottom)); } }

/* ---------- Toast ---------- */
.toast { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%) translateY(20px); background: var(--bg-deep); color: #fff; padding: 14px 24px; border-radius: 999px; font-size: 14px; font-weight: 600; z-index: 300; opacity: 0; transition: all .25s; pointer-events: none; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
.toast.success { background: #16a34a; }
.toast.error { background: #dc2626; }

/* ---------- Platform brand colours ---------- */
.bg-instagram { background: linear-gradient(135deg,#833AB4,#E1306C,#F77737); }
.bg-tiktok { background: #000; }
.bg-youtube { background: #FF0000; }
.bg-spotify { background: #1DB954; }
.bg-facebook { background: #1877F2; }
.bg-x { background: #000; }

[hidden] { display: none !important; }

/* ===========================================
   HERO — diagonal split (v9 redesign)
   Overrides earlier .hero/.hero-* styles via cascade order
   =========================================== */

.hero {
  position: relative;
  overflow: hidden;
  background: #fff;
  padding: 0;
  min-height: 680px;
  display: flex;
  align-items: stretch;
}
.hero-dark {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, #0c0a1a 0%, #1d1437 50%, #4F46E5 100%);
  clip-path: polygon(0 0, 68% 0, 42% 100%, 0 100%);
}
.hero-dark::before {
  content: ''; position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.5) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity: 0.08;
  pointer-events: none;
}
.hero-glow {
  position: absolute;
  width: 500px; height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(192,132,252,0.45) 0%, transparent 70%);
  top: -180px; left: -80px;
  filter: blur(20px);
  pointer-events: none;
}
.hero-inner {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  width: 100%;
  align-items: center;
  position: relative;
  z-index: 2;
  padding: 80px 24px;
  gap: 60px;
  max-width: 1200px;
  margin: 0 auto;
}
@media (max-width: 940px) {
  .hero { min-height: auto; }
  .hero-inner { grid-template-columns: 1fr; gap: 50px; padding: 64px 22px; }
  .hero-dark { clip-path: polygon(0 0, 100% 0, 100% 62%, 0 50%); }
}
@media (max-width: 560px) {
  .hero-inner { padding: 48px 20px 56px; gap: 56px; }
  .hero-dark { clip-path: polygon(0 0, 100% 0, 100% 60%, 0 50%); }
}

/* Left content */
.hero-left { color: #fff; }
.hero-tag {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 7px 14px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 999px;
  font-size: 12px; font-weight: 700; color: #fff;
  margin-bottom: 22px;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.hero-tag .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: #10b981;
  box-shadow: 0 0 0 0 rgba(16,185,129,0.5);
  animation: pulse 2s infinite;
}
.hero-left h1 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(40px, 6vw, 76px);
  color: #fff;
  font-weight: 800;
  line-height: 0.96;
  letter-spacing: -0.04em;
  margin-bottom: 22px;
}
.hero-left h1 .grad-c {
  background: linear-gradient(120deg, #C084FC, #A855F7, #22D3EE);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero-left .hero-sub {
  font-size: 18px;
  color: rgba(255,255,255,0.75);
  max-width: 480px;
  margin-bottom: 32px;
  line-height: 1.5;
}
.hero-cta {
  display: flex; gap: 12px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}
.btn-lime {
  background: #C3FF36; color: #0c0a1a;
  box-shadow: 0 12px 30px rgba(195,255,54,0.35);
}
.btn-lime:hover { transform: translateY(-2px); box-shadow: 0 14px 40px rgba(195,255,54,0.5); }
.btn-ghost-dark {
  background: transparent;
  border: 1.5px solid rgba(255,255,255,0.25);
  color: #fff;
}
.btn-ghost-dark:hover { background: rgba(255,255,255,0.08); border-color: rgba(255,255,255,0.5); }

/* Trust row (overrides earlier hero-trust for dark context) */
.hero-trust { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.hero-trust .avs { display: flex; }
.hero-trust .avs span {
  width: 36px; height: 36px; border-radius: 50%;
  border: 2.5px solid #0c0a1a;
  margin-left: -10px;
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff; font-weight: 800; font-size: 12px;
}
.hero-trust .avs span:nth-child(1) { background: #7C3AED; margin-left: 0; }
.hero-trust .avs span:nth-child(2) { background: #A855F7; }
.hero-trust .avs span:nth-child(3) { background: #22D3EE; }
.hero-trust .avs span:nth-child(4) { background: #10b981; }
.hero-trust .txt { font-size: 13px; color: rgba(255,255,255,0.7); }
.hero-trust .txt strong { color: #fff; font-weight: 800; font-size: 14px; }
.hero-trust .txt .stars { color: #FFD56B; letter-spacing: 1px; font-size: 13px; }

/* Right side — profile card */
.hero-right { position: relative; }
.hero-card {
  background: #fff;
  border-radius: 24px;
  padding: 26px;
  box-shadow: 0 30px 80px rgba(0,0,0,0.25);
  max-width: 380px;
  margin-left: auto;
  border: 1px solid var(--line);
}
@media (max-width: 940px) {
  .hero-card { margin: 0 auto; }
}
.hc-head { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.hc-av {
  width: 54px; height: 54px; border-radius: 50%;
  background: var(--grad-bright); padding: 3px;
}
.hc-av div {
  width: 100%; height: 100%; border-radius: 50%;
  background: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; color: var(--purple); font-size: 20px;
  font-family: 'Bricolage Grotesque', sans-serif;
}
.hc-name {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 17px;
  display: flex; align-items: center; gap: 6px;
}
.hc-name .v {
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--purple); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 10px;
}
.hc-handle { font-size: 13px; color: var(--muted); }
.hc-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  text-align: center;
  gap: 8px;
  padding: 14px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-bottom: 16px;
}
.hc-stats .n {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 20px;
}
.hc-stats .l {
  font-size: 10px; color: var(--muted);
  text-transform: uppercase; letter-spacing: 0.06em;
}
.hc-chart {
  background: var(--soft-purple);
  border-radius: 12px;
  padding: 14px;
}
.hc-chart-top {
  font-size: 10px; font-weight: 800; color: var(--muted);
  text-transform: uppercase; letter-spacing: 0.08em;
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 8px;
}
.hc-chart-top .v {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 22px; color: var(--purple);
  text-transform: none; letter-spacing: -0.02em;
}
.hc-chart-top .v small {
  font-size: 12px; color: #10b981; font-weight: 800;
  font-family: 'Inter', sans-serif;
}
.hc-chart svg { width: 100%; height: 50px; display: block; }

/* Floats */
.hero-float-1 {
  position: absolute;
  top: -20px; right: -10px;
  background: var(--grad);
  color: #fff;
  padding: 12px 18px;
  border-radius: 14px;
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800; font-size: 14px;
  box-shadow: var(--sh-glow);
  transform: rotate(6deg);
  z-index: 3;
  animation: floaty 4s ease-in-out infinite;
}
.hero-float-1 small {
  display: block;
  font-family: 'Inter', sans-serif;
  font-size: 10px; font-weight: 600;
  opacity: 0.85;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 3px;
}
.hero-float-2 {
  position: absolute;
  bottom: -20px; left: -30px;
  background: #fff; color: var(--ink);
  padding: 10px 16px;
  border-radius: 14px;
  font-weight: 700; font-size: 13px;
  box-shadow: var(--sh);
  transform: rotate(-5deg);
  display: flex; align-items: center; gap: 8px;
  z-index: 3;
  animation: floaty 4s ease-in-out infinite 1.5s;
}
.hero-float-2 .ico {
  width: 24px; height: 24px; border-radius: 6px;
  background: #10b981; color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px;
}
@media (max-width: 940px) {
  .hero-float-1 { top: -16px; right: 12px; }
  .hero-float-2 { bottom: -16px; left: 12px; }
}

/* Trust strip below the hero */
.trust-strip {
  background: #fff;
  border-bottom: 1px solid var(--line);
  padding: 22px 0;
  position: relative;
  z-index: 4;
}

/* ===========================================
   HERO — mobile optimisations
   =========================================== */

@media (max-width: 768px) {
  /* Hero container — let it size naturally */
  .hero { min-height: auto; }

  /* Diagonal becomes a clean horizontal split */
  .hero-dark { clip-path: polygon(0 0, 100% 0, 100% 90%, 0 100%); }

  /* Inner — single column, snug paddings */
  .hero-inner {
    grid-template-columns: 1fr;
    gap: 32px;
    padding: 44px 20px 0;
    max-width: 100%;
  }

  /* Left content — tighter typography */
  .hero-tag {
    font-size: 11px;
    padding: 6px 12px;
    margin-bottom: 18px;
  }
  .hero-left h1 {
    font-size: 42px;
    line-height: 1.02;
    margin-bottom: 16px;
  }
  .hero-left .hero-sub {
    font-size: 15px;
    margin-bottom: 24px;
    line-height: 1.5;
  }

  /* CTAs — stack full width on phones */
  .hero-cta {
    flex-direction: column;
    gap: 10px;
    margin-bottom: 26px;
  }
  .hero-cta .btn { width: 100%; }
  .hero-cta .btn-lg { padding: 15px 28px; font-size: 15px; }

  /* Bump ghost button contrast on the dark bg */
  .btn-ghost-dark {
    background: rgba(255,255,255,0.10);
    border-color: rgba(255,255,255,0.40);
  }

  /* Trust row inside hero — tighter */
  .hero-trust { gap: 12px; padding-bottom: 6px; }
  .hero-trust .avs span { width: 32px; height: 32px; font-size: 11px; border-width: 2px; }
  .hero-trust .txt { font-size: 12px; }
  .hero-trust .txt strong { font-size: 13px; }

  /* Right side — card sits below the dark area, centered, no awkward overflows */
  .hero-right { padding: 18px 4px 56px; }
  .hero-card { max-width: 100%; padding: 22px; margin: 0 auto; }

  /* Float pills — reposition so they don't cover the username */
  .hero-float-1 {
    top: -14px; right: 8px;
    padding: 9px 14px;
    font-size: 12px;
    transform: rotate(4deg);
  }
  .hero-float-1 small { font-size: 9px; margin-top: 2px; }
  .hero-float-2 {
    bottom: -14px; left: 50%;
    transform: translateX(-50%) rotate(-3deg);
    padding: 9px 14px;
    font-size: 12px;
  }

  /* Trust strip BELOW the hero — 2x2 grid on phones */
  .trust-strip { padding: 22px 0; }
  .trust-strip .trust-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px 10px;
    justify-items: start;
  }
  .trust-strip .trust-item {
    font-size: 12px;
    gap: 6px;
    align-items: center;
    white-space: nowrap;
  }
  .trust-strip .trust-item svg { width: 16px; height: 16px; flex-shrink: 0; }
  .trust-strip .trust-sep { display: none; }

  /* The "Secure payment" item — keep label inline, shrink the badges so the row fits */
  .trust-strip .trust-pay { flex-direction: row; align-items: center; gap: 6px; }
  .trust-strip .trust-pay .trust-pay-label { display: none; }
  .trust-strip .pay-badges { gap: 3px; }
  .trust-strip .pay-badges .pay { height: 16px; min-width: 22px; padding: 0 4px; font-size: 8px; }
  .trust-strip .pay-badges .pay-mc i { width: 8px; height: 8px; }
}

/* Smaller phones — extra-snug */
@media (max-width: 400px) {
  .hero-left h1 { font-size: 38px; }
  .hero-inner { padding: 36px 18px 0; }
  .hero-right { padding: 14px 4px 50px; }
}

/* ===========================================
   HERO — mobile redesign v2
   Treat mobile as its own composition:
     • Dark area = full-width statement (headline, sub, CTAs, trust)
     • Card area = white "sheet" rising up with rounded top, eyebrow + card
   =========================================== */

@media (max-width: 768px) {
  .hero {
    background: linear-gradient(135deg, #0c0a1a 0%, #1d1437 55%, #4F46E5 100%);
    min-height: auto;
    padding: 0;
    overflow: hidden;
    position: relative;
  }

  /* Hide the diagonal — mobile doesn't need it */
  .hero-dark { display: none; }

  /* Stronger central glow */
  .hero-glow {
    display: block;
    width: 700px; height: 700px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(192,132,252,0.42) 0%, transparent 65%);
    top: -300px; left: 50%;
    transform: translateX(-50%);
    filter: blur(60px);
    z-index: 0;
  }

  /* Add subtle dot texture across the whole dark area */
  .hero::before {
    content: ''; position: absolute; inset: 0;
    background-image: radial-gradient(rgba(255,255,255,0.5) 1px, transparent 1px);
    background-size: 3px 3px;
    opacity: 0.06;
    pointer-events: none;
    z-index: 1;
  }

  .hero-inner {
    grid-template-columns: 1fr;
    gap: 0;
    padding: 0;
    max-width: 100%;
    position: relative;
    z-index: 2;
  }

  /* ----- DARK SECTION (statement) ----- */
  .hero-left {
    padding: 56px 22px 62px;
  }
  .hero-tag {
    font-size: 11px;
    padding: 7px 13px;
    margin-bottom: 22px;
  }
  .hero-left h1 {
    font-size: 50px;
    line-height: 0.98;
    letter-spacing: -0.045em;
    margin-bottom: 18px;
  }
  .hero-left .hero-sub {
    font-size: 16px;
    margin-bottom: 28px;
    line-height: 1.5;
    color: rgba(255,255,255,0.78);
  }
  .hero-cta {
    flex-direction: column;
    gap: 10px;
    margin-bottom: 28px;
  }
  .hero-cta .btn {
    width: 100%;
    padding: 16px 28px;
    font-size: 15.5px;
  }
  .btn-ghost-dark {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.32);
  }
  /* Avatars + rating row */
  .hero-trust { gap: 14px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.10); }
  .hero-trust .avs span { width: 34px; height: 34px; font-size: 12px; border-width: 2.5px; }
  .hero-trust .txt { font-size: 12.5px; }
  .hero-trust .txt strong { font-size: 13.5px; }
  .hero-trust .txt .stars { font-size: 12.5px; }

  /* ----- LIGHT SHEET (card showcase) ----- */
  .hero-right {
    background: linear-gradient(180deg, #fff 0%, #faf8ff 100%);
    padding: 44px 22px 60px;
    margin-top: -28px;
    border-top-left-radius: 34px;
    border-top-right-radius: 34px;
    position: relative;
    z-index: 3;
    box-shadow: 0 -16px 50px rgba(0,0,0,0.15);
  }
  .hero-right::before {
    content: 'Real growth looks like this';
    display: block;
    text-align: center;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 800;
    color: var(--purple);
    text-transform: uppercase;
    letter-spacing: 0.14em;
    margin-bottom: 22px;
  }
  .hero-card {
    max-width: 100%;
    margin: 0 auto;
    padding: 22px;
    border-radius: 22px;
    box-shadow: 0 20px 60px rgba(76,29,149,0.18);
  }
  .hc-head { gap: 14px; margin-bottom: 18px; }
  .hc-av { width: 56px; height: 56px; }
  .hc-av div { font-size: 22px; }
  .hc-name { font-size: 18px; }
  .hc-handle { font-size: 13px; }
  .hc-stats { padding: 16px 0; margin-bottom: 16px; }
  .hc-stats .n { font-size: 22px; }
  .hc-stats .l { font-size: 10px; }
  .hc-chart { padding: 16px; }
  .hc-chart-top .v { font-size: 22px; }
  .hc-chart svg { height: 56px; }

  /* Floats — bigger, more confident */
  .hero-float-1 {
    top: 16px; right: -6px;
    padding: 11px 16px;
    font-size: 13px;
    transform: rotate(6deg);
    box-shadow: 0 14px 36px rgba(124,58,237,0.45);
  }
  .hero-float-1 small { font-size: 10px; margin-top: 3px; }
  .hero-float-2 {
    bottom: -18px;
    left: 50%;
    transform: translateX(-50%) rotate(-3deg);
    padding: 10px 15px;
    font-size: 13px;
    box-shadow: 0 14px 36px rgba(0,0,0,0.12);
  }

  /* ----- TRUST STRIP — keep 2x2 grid but with breathing room ----- */
  .trust-strip {
    background: linear-gradient(180deg, #faf8ff 0%, #fff 100%);
    padding: 26px 0 28px;
    border-bottom: 1px solid var(--line);
  }
  .trust-strip .trust-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px 12px;
    justify-items: start;
    padding: 0 6px;
  }
  .trust-strip .trust-item {
    font-size: 12px;
    gap: 7px;
    align-items: center;
    white-space: nowrap;
    color: var(--ink-2);
    font-weight: 700;
  }
  .trust-strip .trust-item svg { width: 16px; height: 16px; flex-shrink: 0; }
  .trust-strip .trust-sep { display: none; }
  .trust-strip .trust-pay { flex-direction: row; align-items: center; gap: 6px; }
  .trust-strip .trust-pay .trust-pay-label { display: none; }
  .trust-strip .pay-badges { gap: 3px; }
  .trust-strip .pay-badges .pay { height: 16px; min-width: 22px; padding: 0 4px; font-size: 8px; }
  .trust-strip .pay-badges .pay-mc i { width: 8px; height: 8px; }
}

/* Smaller phones */
@media (max-width: 400px) {
  .hero-left { padding: 48px 18px 56px; }
  .hero-left h1 { font-size: 44px; }
  .hero-right { padding: 38px 18px 54px; }
}

/* Hide floating pills on mobile — they look cramped, card stands better alone */
@media (max-width: 768px) {
  .hero-float-1,
  .hero-float-2 { display: none; }
  /* Compensate by giving the card a small "live" indicator built-in */
  .hero-card .hc-head { position: relative; }
  .hero-card .hc-head::after {
    content: '● live';
    position: absolute;
    top: -2px; right: -2px;
    font-size: 9px;
    font-weight: 800;
    color: #10b981;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    display: inline-flex;
    align-items: center;
    gap: 3px;
    padding: 4px 8px;
    background: rgba(16,185,129,0.10);
    border-radius: 999px;
  }
}

/* ===========================================
   MOBILE — full-site optimisation pass
   Tighter padding, snappier typography, better rhythm
   =========================================== */

@media (max-width: 560px) {

  /* Section base — tighter than 70px on phones */
  .section { padding: 52px 0; }
  .sheet { padding-top: 44px; border-radius: 26px 26px 0 0; margin-top: -26px; }

  /* Section head — controls h2 + eyebrow + lead */
  .center { padding: 0 4px; }
  .h2, .section-h { font-size: 30px !important; line-height: 1.05; letter-spacing: -0.03em; margin-bottom: 12px; }
  .center .lead, .lead { font-size: 15px; line-height: 1.55; }
  .eyebrow { font-size: 11px; margin-bottom: 12px; }

  /* Stats grid (By the numbers) */
  .stats-grid { gap: 12px; margin-top: 32px; }
  .stat-card { padding: 24px 16px; border-radius: 18px; }
  .stat-ico { width: 38px; height: 38px; }
  .stat-num { font-size: 30px; }
  .stat-lbl { font-size: 10px; margin-top: 6px; }

  /* Platforms grid (Pick your platform) */
  .pp-grid { gap: 10px; margin-top: 30px; }
  .pp-card { padding: 18px 10px; border-radius: 16px; }
  .pp-ico { width: 44px; height: 44px; margin-bottom: 10px; }
  .pp-name { font-size: 13px; }
  .pp-from { font-size: 11px; margin-top: 3px; }

  /* Showcase tabs + panel */
  .showcase-tabs { gap: 6px; margin: 24px 0 28px; padding: 0 8px; }
  .showcase-tab { padding: 9px 14px; font-size: 12px; }
  .showcase-panel.active { gap: 28px; }
  .showcase-h { font-size: 24px !important; margin-bottom: 12px; }
  .showcase-p { font-size: 14px; margin-bottom: 20px; }
  .showcase-checks { gap: 10px; margin-bottom: 22px; }
  .showcase-checks li { font-size: 13px; }
  .showcase-card { padding: 22px 20px; border-radius: 22px; }

  /* Estimator */
  .estimator .center { padding: 0 10px; }
  .est-box { padding: 24px 20px; border-radius: 22px; margin-top: 28px; }
  .est-row { margin-bottom: 22px; }
  .est-label { font-size: 12px; }
  .est-platforms button { padding: 9px 14px; font-size: 12px; }
  .est-goal { font-size: 14px; }
  .est-result { padding: 18px 18px; gap: 14px; }
  .est-result-pkg { font-size: 18px; }
  .est-result-price { font-size: 26px; }

  /* How it works */
  .hiw-grid { gap: 18px; margin-top: 32px; }
  .hiw-card { padding: 26px 22px; border-radius: 20px; }
  .hiw-num { width: 54px; height: 54px; margin-bottom: 14px; }
  .hiw-num svg { width: 24px; height: 24px; }
  .hiw-num span { width: 22px; height: 22px; font-size: 11px; top: -6px; right: -6px; }
  .hiw-step { font-size: 10px; margin-bottom: 6px; }
  .hiw-h { font-size: 18px; }
  .hiw-p { font-size: 13.5px; line-height: 1.5; }

  /* Bento (Why IGFollowers) */
  .bento { gap: 12px; margin-top: 32px; }
  .bento-card { padding: 22px 20px; border-radius: 20px; }
  .bento-ico { width: 40px; height: 40px; margin-bottom: 12px; }
  .bento-stat { font-size: 34px; }
  .bento-h { font-size: 17px; }
  .bento-p { font-size: 13.5px; line-height: 1.5; }

  /* Activity feed */
  .activity-wrap { gap: 26px; margin-top: 32px; }
  .activity-feed { padding: 8px; border-radius: 22px; }
  .activity-head { padding: 6px 8px 4px; }

  /* Reviews grid */
  .rv-grid { gap: 14px; margin-top: 32px; }
  .rv { padding: 22px 20px; border-radius: 20px; }
  .rv::before { font-size: 60px; top: 4px; right: 16px; }
  .rv-title { font-size: 15px; }
  .rv-body { font-size: 13.5px; line-height: 1.55; margin-bottom: 14px; }
  .rv-foot { gap: 9px; }
  .rv-av { width: 34px; height: 34px; font-size: 13px; }
  .rv-name { font-size: 12.5px; }
  .rv-time { font-size: 10.5px; }
  .rv-badge { font-size: 9px; padding: 3px 7px; }

  /* FAQ */
  .faq-list { gap: 10px; }
  .faq-item { border-radius: 16px; }
  .faq-q { padding: 16px 18px; font-size: 14.5px; }
  .faq-q::after { font-size: 22px; }
  .faq-a { font-size: 14px; padding: 0 18px 18px; line-height: 1.6; }

  /* Final CTA */
  .final-cta { padding: 60px 20px; }
  .final-cta-inner h2 { font-size: 36px !important; line-height: 1.02; letter-spacing: -0.035em; }
  .final-cta-inner p { font-size: 15px; margin-bottom: 24px; }
  .final-cta-trust { gap: 14px; font-size: 11px; margin-top: 18px; flex-wrap: wrap; justify-content: center; }
  .final-cta .btn-lg { padding: 16px 28px; font-size: 15px; }
}

/* Smaller phones — extra-tight */
@media (max-width: 380px) {
  .h2, .section-h { font-size: 28px !important; }
  .stat-num { font-size: 26px; }
  .bento-stat { font-size: 30px; }
}

/* ===========================================
   SITE-WIDE — match the hero's dark / lime style
   =========================================== */

/* Primary button → lime (same as hero CTA, used everywhere) */
.btn-primary {
  background: #C3FF36;
  color: #0c0a1a;
  box-shadow: 0 12px 30px rgba(195,255,54,0.35);
}
.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 40px rgba(195,255,54,0.5);
  background: #d4ff5a;
}

/* Helper to use cyan/purple gradient text (matches hero's "unmissable.") */
.grad-c {
  background: linear-gradient(120deg, #C084FC, #A855F7, #22D3EE);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* ----- Dark sections — unified hero-style treatment ----- */
.estimator,
.final-cta {
  background: linear-gradient(135deg, #0c0a1a 0%, #1d1437 50%, #4F46E5 100%);
}
.estimator::before,
.final-cta::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.5) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity: 0.06;
  pointer-events: none;
  z-index: 0;
}
/* Hide old simple orbs on dark sections — replace with central glow */
.estimator .hero-orb,
.final-cta .hero-orb { display: none; }
.estimator .center,
.final-cta-inner { position: relative; z-index: 2; }

/* Big central glow on dark sections */
.estimator > .wrap::before,
.final-cta-inner::before {
  content: '';
  position: absolute;
  width: 700px; height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(192,132,252,0.30) 0%, transparent 65%);
  top: -250px; left: 50%;
  transform: translateX(-50%);
  filter: blur(40px);
  pointer-events: none;
  z-index: 0;
}
.estimator > .wrap,
.final-cta-inner { position: relative; }

/* Estimator — refresh inner card */
.est-box {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.10);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.est-platforms button {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.85);
}
.est-platforms button.active {
  background: #C3FF36;
  color: #0c0a1a;
  border-color: #C3FF36;
}
.est-result-price { color: #C3FF36; }
.est-goal { color: #C3FF36; }
/* Estimator CTA → lime */
.estimator .btn-light {
  background: #C3FF36;
  color: #0c0a1a;
  border-color: #C3FF36;
}
.estimator .btn-light:hover { background: #d4ff5a; }

/* Estimator eyebrow → cyan/lime accent */
.estimator .eyebrow {
  color: #C3FF36;
  background: rgba(195,255,54,0.12);
}
.estimator .eyebrow::before,
.estimator .eyebrow::after { display: none; }

/* Final CTA — match hero gradient text on accent */
.final-cta .grad {
  background: linear-gradient(120deg, #C084FC, #A855F7, #22D3EE);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.final-cta h2 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 0.98;
}
.final-cta-trust { color: rgba(255,255,255,0.6); }
.final-cta-trust span { color: rgba(255,255,255,0.78); font-weight: 600; }

/* ----- Lime stat numbers for visual cohesion ----- */
.stat-num { color: var(--purple); }       /* keep these purple — they're on light bg */
.stat-card:hover .stat-num { color: var(--purple); }

/* Bento "feature" card (currently uses purple gradient) — keep as-is, it's a hero echo */

/* ----- Accent eyebrows site-wide — same purple pill style works on light bg ----- */
/* (already styled, no change needed) */

/* ----- Showcase "Buy <platform>" CTA — already btn-primary, will go lime automatically ----- */

/* ----- Cart drawer CTA + sticky CTA — already btn-primary, will go lime automatically ----- */

/* ===========================================
   "How it works" — typography refinement
   =========================================== */
.hiw-step {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--purple);
  background: var(--soft-purple);
  padding: 4px 10px;
  border-radius: 999px;
  display: inline-block;
  margin-bottom: 14px;
}
.hiw-h {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 24px;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.08;
  margin-bottom: 10px;
}
.hiw-p {
  font-size: 14.5px;
  color: var(--muted);
  line-height: 1.6;
}

@media (max-width: 560px) {
  .hiw-step { font-size: 10px; padding: 3px 9px; margin-bottom: 12px; }
  .hiw-h { font-size: 21px; }
  .hiw-p { font-size: 14px; line-height: 1.55; }
}

/* Hero headline — tiny size reduction across the board */
.hero-left h1 { font-size: clamp(38px, 5.4vw, 66px); }
@media (max-width: 768px) { .hero-left h1 { font-size: 44px; } }
@media (max-width: 400px) { .hero-left h1 { font-size: 40px; } }

/* ===========================================
   Section separation + stats card refresh
   Stops the trust strip / stats / platforms area
   from blending into one big white block
   =========================================== */

/* Trust strip — subtle separator from the section below */
.trust-strip {
  border-bottom: 1px solid var(--line);
  box-shadow: 0 4px 16px rgba(76,29,149,0.04);
}

/* Stats section — give it a subtle tinted background + texture */
.section.sheet.bg-white {
  background: linear-gradient(180deg, #fff 0%, #faf8ff 100%);
  position: relative;
}

/* Stat cards — proper visual treatment */
.stat-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 22px;
  padding: 32px 22px;
  text-align: center;
  transition: transform .2s, box-shadow .2s, border-color .2s;
  position: relative;
  overflow: hidden;
}
.stat-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, transparent 0%, rgba(124,58,237,0.04) 100%);
  pointer-events: none;
  opacity: 0;
  transition: opacity .25s;
}
.stat-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 24px 60px rgba(76,29,149,0.18);
  border-color: rgba(124,58,237,0.20);
}
.stat-card:hover::before { opacity: 1; }

/* Stat icon — gradient-filled instead of soft-purple flat */
.stat-ico {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: var(--grad);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 18px;
  box-shadow: 0 10px 26px rgba(124,58,237,0.30);
  position: relative;
  z-index: 1;
}
.stat-ico svg {
  width: 24px;
  height: 24px;
  stroke: #fff;
  fill: none;
  stroke-width: 2.2;
}

/* Stat numbers — use the cyan/purple gradient text */
.stat-num {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 44px;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
  background: linear-gradient(120deg, #7C3AED, #A855F7, #22D3EE);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  position: relative;
  z-index: 1;
}
.stat-lbl {
  font-size: 11px;
  font-weight: 800;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-top: 8px;
  position: relative;
  z-index: 1;
}

/* Tighten breathing room between trust strip and stats heading */
.trust-strip + .section.sheet { padding-top: 44px; margin-top: -26px; }
@media (min-width: 768px) {
  .trust-strip + .section.sheet { padding-top: 56px; }
}

/* Mobile adjustments */
@media (max-width: 560px) {
  .stat-card { padding: 24px 18px; border-radius: 18px; }
  .stat-ico { width: 44px; height: 44px; margin-bottom: 14px; border-radius: 13px; }
  .stat-ico svg { width: 20px; height: 20px; }
  .stat-num { font-size: 32px; }
  .stat-lbl { font-size: 10px; margin-top: 6px; }
}

/* ===========================================
   Trust strip — make it match the dark hero feel
   =========================================== */
.trust-strip {
  background: linear-gradient(135deg, #0c0a1a 0%, #1d1437 50%, #4F46E5 100%);
  padding: 22px 0;
  border-bottom: none;
  box-shadow: none;
  position: relative;
  overflow: hidden;
}
.trust-strip::before {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.5) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity: 0.07;
  pointer-events: none;
}
.trust-strip .wrap { position: relative; z-index: 2; }

.trust-strip .trust-row { gap: 14px 28px; }
.trust-strip .trust-item {
  color: #fff;
  font-weight: 700;
  font-size: 13.5px;
}
.trust-strip .trust-item svg {
  stroke: #C3FF36;
  filter: drop-shadow(0 0 10px rgba(195,255,54,0.4));
}
.trust-strip .trust-sep {
  background: rgba(255,255,255,0.16);
  height: 18px;
}
.trust-strip .trust-pay-label { color: #fff; }
.trust-strip .trust-pay svg { stroke: #C3FF36; }

/* Mobile — keep the 2x2 grid layout, just on the dark bg */
@media (max-width: 560px) {
  .trust-strip { padding: 22px 0; }
  .trust-strip .trust-item { color: rgba(255,255,255,0.92); }
  .trust-strip .trust-item svg { stroke: #C3FF36; }
}

/* ===========================================
   Trust strip — floating pill design
   Light surround, dark gradient pill in the middle
   =========================================== */
.trust-strip {
  background: #fff;
  padding: 30px 22px;
  border-bottom: none;
  box-shadow: none;
  position: relative;
  overflow: visible;
}
.trust-strip::before { display: none; }
.trust-strip .wrap { max-width: 980px; margin: 0 auto; position: relative; z-index: 2; padding: 0; }

.trust-strip .trust-row {
  background: linear-gradient(135deg, #0c0a1a 0%, #1d1437 50%, #4F46E5 100%);
  border-radius: 999px;
  padding: 18px 36px;
  margin: 0;
  position: relative;
  overflow: hidden;
  box-shadow: 0 20px 50px rgba(76,29,149,0.28);
  gap: 14px 28px;
  justify-content: center;
}
.trust-strip .trust-row::after {
  content: '';
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.5) 1px, transparent 1px);
  background-size: 3px 3px;
  opacity: 0.07;
  pointer-events: none;
}
.trust-strip .trust-item { position: relative; z-index: 1; }
.trust-strip .trust-sep { background: rgba(255,255,255,0.16); position: relative; z-index: 1; }

/* Make the sheet below sit flush against the white trust-strip (no rising lip) */
.trust-strip + .section.sheet { margin-top: 0; padding-top: 56px; border-radius: 0; }

/* Mobile — pill becomes a rounded card so 2x2 grid fits */
@media (max-width: 560px) {
  .trust-strip { padding: 22px 16px; }
  .trust-strip .trust-row {
    border-radius: 24px;
    padding: 22px 20px;
    box-shadow: 0 14px 40px rgba(76,29,149,0.24);
  }
  .trust-strip + .section.sheet { padding-top: 44px; }
}

/* ===========================================
   Trust pill — lighter colour, one line, overlaps hero
   =========================================== */
.trust-strip {
  background: transparent;
  padding: 0;
  margin-top: -32px;
  position: relative;
  z-index: 10;
  border-bottom: none;
  box-shadow: none;
}
.trust-strip::before { display: none; }
.trust-strip .wrap { max-width: 1100px; margin: 0 auto; padding: 0 22px; position: relative; z-index: 2; }

.trust-strip .trust-row {
  background: rgba(255,255,255,0.95);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,0.7);
  border-bottom: none;
  border-radius: 34px 34px 0 0;
  padding: 14px 28px;
  margin: 0;
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: center;
  gap: 24px;
  box-shadow: 0 -8px 30px rgba(76,29,149,0.18), 0 22px 60px rgba(76,29,149,0.06);
  overflow: hidden;
}
.trust-strip .trust-row::after { display: none; }

.trust-strip .trust-item {
  color: var(--ink-2);
  font-weight: 700;
  font-size: 13px;
  white-space: nowrap;
  position: relative;
  z-index: 1;
}
.trust-strip .trust-item svg {
  stroke: var(--purple);
  filter: none;
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}
.trust-strip .trust-sep {
  background: var(--line);
  height: 16px;
  display: inline-block;
}
.trust-strip .trust-pay-label { color: var(--ink-2); display: inline; }

/* The white sheet sits right under the pill */
.trust-strip + .section.sheet { margin-top: 0; padding-top: 32px; border-radius: 0; }

/* Mobile — one line, horizontal scroll if it doesn't all fit */
@media (max-width: 768px) {
  .trust-strip { margin-top: -22px; }
  .trust-strip .wrap { padding: 0 12px; }
  .trust-strip .trust-row {
    padding: 12px 18px;
    gap: 16px;
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    justify-content: flex-start;
    scrollbar-width: none;
    -ms-overflow-style: none;
  }
  .trust-strip .trust-row::-webkit-scrollbar { display: none; }
  .trust-strip .trust-item { font-size: 11.5px; gap: 5px; flex-shrink: 0; }
  .trust-strip .trust-item svg { width: 13px; height: 13px; }
  .trust-strip .trust-sep { height: 12px; flex-shrink: 0; }
  .trust-strip .trust-pay { flex-direction: row; align-items: center; gap: 6px; }
  .trust-strip .trust-pay .trust-pay-label { display: none; }
  .trust-strip .pay-badges { gap: 3px; }
  .trust-strip .pay-badges .pay { height: 14px; min-width: 20px; padding: 0 3px; font-size: 7.5px; }
  .trust-strip .pay-badges .pay-mc i { width: 7px; height: 7px; }
  .trust-strip + .section.sheet { padding-top: 28px; }
}

/* Trust pill — extend to the full container width */
.trust-strip .wrap { max-width: none; padding: 0 22px; }
@media (max-width: 768px) {
  .trust-strip .wrap { padding: 0 16px; }
}

/* Trust pill — edge to edge, no side padding */
.trust-strip .wrap { padding: 0; max-width: none; }
@media (max-width: 768px) { .trust-strip .wrap { padding: 0; } }

/* Trust pill — softer lavender colour that bridges the hero & stats sections */
.trust-strip .trust-row {
  background: linear-gradient(180deg, #f2ecfe 0%, #faf8ff 100%);
  border: 1px solid rgba(124,58,237,0.12);
  box-shadow: 0 16px 44px rgba(76,29,149,0.18);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}
.trust-strip .trust-item { color: var(--ink-2); }
.trust-strip .trust-item svg { stroke: var(--purple); }
.trust-strip .trust-sep { background: rgba(124,58,237,0.18); }
.trust-strip .trust-pay-label { color: var(--ink-2); }

/* Trust pill — sit on a lavender band that hides the hero's blue bottom edge */
.trust-strip {
  background: linear-gradient(180deg, #f2ecfe 0%, #faf8ff 100%);
  margin-top: 0;
  padding: 20px 0;
  position: relative;
  z-index: 8;
}
.trust-strip .trust-row {
  margin-top: -50px;
  background: linear-gradient(180deg, #f9f5ff 0%, #fff 100%);
  border: 1px solid rgba(124,58,237,0.14);
}
.trust-strip + .section.sheet { padding-top: 18px; }

@media (max-width: 768px) {
  .trust-strip { padding: 16px 0; }
  .trust-strip .trust-row { margin-top: -34px; }
  .trust-strip + .section.sheet { padding-top: 16px; }
}

/* Hero — make it a bit taller on desktop */
.hero { min-height: 780px; }
.hero-inner { padding: 110px 24px; }

/* Hero — dial back the height slightly */
.hero { min-height: 720px; }
.hero-inner { padding: 90px 24px; }

/* Trust pill band — fade the lavender into white at the bottom */
.trust-strip {
  background: linear-gradient(180deg, #f2ecfe 0%, #f6f0ff 40%, #fdfbff 80%, #ffffff 100%);
}

/* Mobile — undo the desktop hero height bumps so the phone view stays snug */
@media (max-width: 768px) {
  .hero { min-height: auto; }
  .hero-inner { padding: 44px 20px 0; }
}

/* Mobile — tighten hero top padding so the badge sits close to the header */
@media (max-width: 768px) {
  .hero-inner { padding: 12px 20px 0; }
  .hero-left { padding: 28px 0 50px; }

  /* Show only the 2 most important trust items on mobile */
  .trust-strip .trust-item:nth-of-type(n+3) { display: none; }
  .trust-strip .trust-row { justify-content: center; gap: 20px; overflow: visible; }
  .trust-strip .trust-sep:nth-of-type(1) { display: inline-block; background: rgba(124,58,237,0.18); height: 16px; }
}

/* Mobile trust pill — center 2 items, no horizontal scroll needed */
@media (max-width: 768px) {
  .trust-strip .trust-row {
    overflow: visible;
    justify-content: center;
    gap: 20px;
    flex-wrap: nowrap;
    padding: 16px 22px;
  }
  .trust-strip .trust-item { font-size: 13px; gap: 7px; }
  .trust-strip .trust-item svg { width: 16px; height: 16px; }
}

/* Mobile trust pill — show only the first 2 trust items + 1 separator */
@media (max-width: 768px) {
  .trust-strip .trust-row > :nth-child(n+4) { display: none !important; }
  .trust-strip .trust-row > .trust-sep:first-of-type {
    display: inline-block !important;
    width: 1px;
    height: 14px;
    background: rgba(124,58,237,0.20);
  }
  .trust-strip .trust-item:nth-of-type(n+3) { display: revert !important; }
  /* explicit hide of items 3 & 4 + all seps after the first */
}

/* Mobile trust pill — final cleanup: just 2 items + separator */
@media (max-width: 768px) {
  /* Nuke previous overrides */
  .trust-strip .trust-item:nth-of-type(n+3) { display: none !important; }
  .trust-strip .trust-row > :nth-child(n+4) { display: none !important; }
  .trust-strip .trust-row > .trust-sep:first-of-type {
    display: inline-block !important;
    width: 1px;
    height: 14px;
    background: rgba(124,58,237,0.20);
  }
  .trust-strip .trust-row {
    justify-content: center !important;
    gap: 18px !important;
    overflow: hidden !important;
  }
}

/* Mobile trust pill — shrink so both items fit on a phone screen */
@media (max-width: 768px) {
  .trust-strip .trust-row {
    padding: 14px 14px !important;
    gap: 12px !important;
  }
  .trust-strip .trust-item { font-size: 11.5px !important; gap: 6px !important; }
  .trust-strip .trust-item svg { width: 14px !important; height: 14px !important; }
}

/* Mobile trust pill — fix selector so Money-back actually shows */
@media (max-width: 768px) {
  /* Reset hides */
  .trust-strip .trust-item:nth-of-type(n+3) { display: inline-flex !important; }
  /* Hide only items 3 & 4 (5th and 7th span) and the seps after position 3 (4th and 6th span) */
  .trust-strip .trust-item:nth-of-type(n+5) { display: none !important; }
  .trust-strip .trust-sep:nth-of-type(n+4) { display: none !important; }
}

/* Mobile-only tweaks */
@media (max-width: 768px) {
  /* Tighter top padding on the live feed section */
  .section.activity { padding-top: 32px; }

  /* Hero card loads instantly on mobile — no scroll-reveal animation */
  .hero-right.reveal,
  .hero-right.reveal.d1,
  .hero-right.reveal.d2,
  .hero-right.reveal.d3 {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* Hero — show the trust pill peeking at the bottom of the first viewport */
@media (min-width: 769px) {
  .hero { min-height: 640px; }
  .hero-inner { padding: 80px 24px; }
}

/* Activity section — align left text to top instead of vertically centered */
.activity-wrap { align-items: start; }
@media (min-width: 880px) { .activity-wrap { align-items: start; } }

/* ===== Product page hero band (matches site hero style) ===== */
.pdp-band { position: relative; overflow: hidden; background: linear-gradient(135deg, #0c0a1a 0%, #1d1437 50%, #4F46E5 100%); color: #fff; padding: 70px 0 96px; }
.pdp-band::before { content: ''; position: absolute; inset: 0; background-image: radial-gradient(rgba(255,255,255,0.08) 1px, transparent 1px); background-size: 28px 28px; opacity: 0.5; pointer-events: none; }
.pdp-band-orb { position: absolute; width: 420px; height: 420px; border-radius: 50%; filter: blur(110px); pointer-events: none; }
.pdp-band-orb.o1 { background: rgba(168,85,247,0.45); top: -160px; right: -80px; }
.pdp-band-orb.o2 { background: rgba(34,211,238,0.28); bottom: -200px; left: -100px; }
.pdp-band .wrap { position: relative; z-index: 1; }
.pdp-band-crumb { font-size: 13px; color: rgba(255,255,255,0.65); margin-bottom: 26px; display: flex; align-items: center; gap: 8px; }
.pdp-band-crumb a { color: rgba(255,255,255,0.65); }
.pdp-band-crumb a:hover { color: #fff; }
.pdp-band-crumb span.sep { color: rgba(255,255,255,0.35); }
.pdp-band-crumb span.now { color: #fff; font-weight: 600; }
.pdp-band-top { display: flex; align-items: flex-start; gap: 22px; max-width: 820px; }
.pdp-band-ico { width: 72px; height: 72px; border-radius: 18px; display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; box-shadow: 0 14px 40px rgba(0,0,0,0.35); color: #fff; }
.pdp-band-ico svg { width: 36px; height: 36px; }
.pdp-band-title { font-family: 'Bricolage Grotesque', sans-serif; font-size: clamp(34px, 5.4vw, 56px); font-weight: 800; line-height: 1.02; letter-spacing: -0.03em; color: #fff; margin: 4px 0 14px; }
.pdp-band-title .grad-c { background: linear-gradient(120deg, #C3FF36 0%, #22D3EE 50%, #C084FC 100%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.pdp-band-desc { font-size: 16px; line-height: 1.6; color: rgba(255,255,255,0.78); max-width: 640px; margin: 0; }
.pdp-band-meta { display: flex; flex-wrap: wrap; gap: 10px 18px; margin-top: 24px; }
.pdp-band-meta span { display: inline-flex; align-items: center; gap: 7px; font-size: 13px; font-weight: 600; color: rgba(255,255,255,0.88); }
.pdp-band-meta span svg { width: 15px; height: 15px; color: #C3FF36; }
.pdp-band-stars { display: inline-flex; align-items: center; gap: 8px; font-size: 13px; color: rgba(255,255,255,0.9); font-weight: 600; }
.pdp-band-stars .stars { color: #FACC15; letter-spacing: 1px; font-size: 13px; }

/* The white PDP section sits below — pull it up to overlap the band slightly */
.pdp-band + .pdp { margin-top: -52px; position: relative; z-index: 2; }
.pdp-band + .pdp .wrap > .pdp-card { background: #fff; border: 1px solid var(--line); border-radius: 24px; box-shadow: 0 30px 70px rgba(20,12,50,0.10); padding: 28px; }
@media (min-width: 980px) { .pdp-band + .pdp .wrap > .pdp-card { padding: 38px; } }
@media (max-width: 560px) {
  .pdp-band { padding: 48px 0 80px; }
  .pdp-band-top { gap: 14px; }
  .pdp-band-ico { width: 56px; height: 56px; border-radius: 14px; }
  .pdp-band-ico svg { width: 28px; height: 28px; }
  .pdp-band-meta { gap: 8px 14px; margin-top: 18px; }
  .pdp-band-desc { font-size: 14.5px; }
  .pdp-band + .pdp { margin-top: -56px; }
  .pdp-band + .pdp .wrap > .pdp-card { padding: 22px 18px; border-radius: 18px; }
}

/* PDP section section label + help button styling for new layout */
.pdp-section-label { font-family: 'Bricolage Grotesque', sans-serif; font-size: 18px; font-weight: 700; letter-spacing: -0.01em; margin: 4px 0 14px; color: var(--ink); }
.pdp-section-sub { font-size: 13px; color: var(--muted); margin: -10px 0 16px; }
.uname-help-btn { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); width: 24px; height: 24px; border-radius: 50%; background: var(--bg-soft); color: var(--muted); font-weight: 800; font-size: 12px; border: 1px solid var(--line); display: inline-flex; align-items: center; justify-content: center; }
.uname-help-btn:hover { color: var(--purple); border-color: var(--purple); }
.uname-help-pop { position: absolute; right: 0; top: calc(100% + 8px); background: #fff; border: 1px solid var(--line); border-radius: 12px; padding: 14px; width: 280px; box-shadow: 0 16px 40px rgba(20,12,50,0.14); font-size: 12.5px; color: var(--muted); z-index: 10; }
.uname-help-pop strong { display: block; color: var(--ink); margin-bottom: 4px; font-weight: 700; font-size: 13px; }
.uname-help-pop code { display: block; margin-top: 6px; padding: 7px 9px; background: var(--bg-soft); border-radius: 8px; font-family: ui-monospace, Menlo, monospace; font-size: 11.5px; color: var(--ink); word-break: break-all; }

/* Trust strip + FAQ on product page */
.pdp-perks { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 16px; margin: 28px 0 0; }
.pdp-perk { background: #fff; border: 1px solid var(--line); border-radius: 16px; padding: 18px; display: flex; gap: 12px; align-items: flex-start; }
.pdp-perk-ico { width: 36px; height: 36px; border-radius: 10px; background: var(--soft-purple); color: var(--purple); display: inline-flex; align-items: center; justify-content: center; flex-shrink: 0; }
.pdp-perk-ico svg { width: 18px; height: 18px; }
.pdp-perk-title { font-size: 14px; font-weight: 700; color: var(--ink); margin: 0 0 3px; }
.pdp-perk-desc { font-size: 12.5px; color: var(--muted); line-height: 1.5; }

.pdp-faq { max-width: 760px; margin: 0 auto; }
.pdp-faq-item { background: #fff; border: 1px solid var(--line); border-radius: 16px; margin-bottom: 12px; overflow: hidden; }
.pdp-faq-q { width: 100%; padding: 18px 22px; display: flex; justify-content: space-between; align-items: center; gap: 16px; font-size: 15px; font-weight: 700; color: var(--ink); text-align: left; background: #fff; }
.pdp-faq-q .plus { color: var(--purple); font-size: 22px; line-height: 1; font-weight: 400; transition: transform .2s; }
.pdp-faq-item.open .pdp-faq-q .plus { transform: rotate(45deg); }
.pdp-faq-a { max-height: 0; overflow: hidden; transition: max-height .25s ease; padding: 0 22px; color: var(--muted); font-size: 14.5px; line-height: 1.6; }
.pdp-faq-item.open .pdp-faq-a { max-height: 240px; padding: 0 22px 18px; }


/* ============================================================
   PROOF SECTION — replaces trust strip + stats grid on homepage
   Big stat tile on left + 2 supporting cards on right.
   ============================================================ */
.proof-section {
  padding: 60px 0;
  background: transparent;
}
/* Stop the next section from pulling up under the proof section
   (the .sheet class has margin-top: -38px by default) */
.proof-section + .section.sheet {
  margin-top: 0 !important;
}
/* Wider wrap so the tiles extend toward the page edges */
.proof-section .wrap {
  max-width: none !important;
  padding-left: 32px !important;
  padding-right: 32px !important;
}
.proof-grid {
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  gap: 16px;
  align-items: stretch;
}
.proof-big {
  background: var(--ink);
  color: #fff;
  border-radius: 24px;
  padding: 44px 44px 36px;
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 320px;
}
.proof-big::after {
  content: '';
  position: absolute;
  width: 420px;
  height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(195,255,54,0.18), transparent 60%);
  bottom: -160px;
  right: -140px;
  filter: blur(70px);
  pointer-events: none;
}
.proof-eye {
  font-size: 11px;
  color: rgba(255,255,255,0.5);
  letter-spacing: 0.15em;
  text-transform: uppercase;
  font-weight: 700;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.proof-eye::before {
  content: '';
  width: 24px;
  height: 1px;
  background: rgba(255,255,255,0.3);
}
.proof-huge {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(80px, 11vw, 132px);
  font-weight: 800;
  letter-spacing: -0.04em;
  line-height: 0.95;
  color: #C3FF36;
  position: relative;
  margin: 20px 0 10px;
}
.proof-sub {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(20px, 2.2vw, 26px);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.2;
  position: relative;
  max-width: 460px;
  color: #fff;
}
.proof-foot {
  margin-top: auto;
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 13px;
  color: rgba(255,255,255,0.7);
  position: relative;
  padding-top: 32px;
  flex-wrap: wrap;
}
.proof-avs { display: flex; }
.proof-avs span {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: 2px solid #1d1437;
  margin-left: -9px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: 800;
  font-size: 12px;
}
.proof-avs span:first-child { margin-left: 0; }
.proof-stars {
  color: #FACC15;
  letter-spacing: 2px;
  font-size: 13px;
}
.proof-rating { font-weight: 500; }
.proof-rating b { color: #fff; font-weight: 700; }

.proof-side {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.proof-card {
  background: #fff;
  border-radius: 24px;
  padding: 28px;
  flex: 1;
  display: flex;
  align-items: center;
  gap: 22px;
  border: 1px solid rgba(12,10,26,0.05);
  box-shadow: 0 3px 10px rgba(12,10,26,0.04);
}
.proof-card-n {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(40px, 5vw, 52px);
  font-weight: 800;
  letter-spacing: -0.035em;
  line-height: 1;
  color: var(--ink);
  min-width: 100px;
}
.proof-card-l {
  font-size: 13.5px;
  color: var(--muted);
  font-weight: 500;
  line-height: 1.5;
}
.proof-card-l b {
  display: block;
  color: var(--ink);
  font-weight: 700;
  font-size: 15px;
  margin-bottom: 3px;
  letter-spacing: -0.01em;
}

/* Mobile */
@media (max-width: 880px) {
  .proof-section { padding: 40px 0; }
  .proof-section .wrap { padding-left: 16px !important; padding-right: 16px !important; }
  .proof-grid { grid-template-columns: 1fr; gap: 12px; }

  .proof-big { padding: 28px 24px 24px; min-height: 0; border-radius: 22px; }
  .proof-eye { font-size: 10px; letter-spacing: 0.12em; }
  .proof-eye::before { width: 18px; }
  .proof-huge { font-size: clamp(64px, 18vw, 84px); margin: 14px 0 8px; }
  .proof-sub { font-size: 18px; max-width: none; }

  /* Foot row: rating text on its own line, avatars + stars on the first */
  .proof-foot {
    padding-top: 20px;
    gap: 10px;
    font-size: 12px;
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-areas: "avs stars" "rating rating";
    align-items: center;
  }
  .proof-avs { grid-area: avs; }
  .proof-stars { grid-area: stars; font-size: 12px; }
  .proof-rating { grid-area: rating; font-size: 12.5px; }

  /* Side cards: smaller number, more room for label */
  .proof-card { padding: 22px; gap: 18px; border-radius: 22px; }
  .proof-card-n { font-size: 38px; min-width: 0; flex-shrink: 0; }
  .proof-card-l { font-size: 13px; }
  .proof-card-l b { font-size: 15px; }
}

@media (max-width: 420px) {
  .proof-huge { font-size: 64px; }
  .proof-sub { font-size: 17px; }
  .proof-card-n { font-size: 34px; }
}

/* ============================================================
   Mobile cleanup pass — proof + platforms + estimator + hero
   ============================================================ */
@media (max-width: 768px) {
  /* 1. Hero card — kill the chunky empty space below the chart card */
  .hero-right { padding: 18px 4px 24px !important; }

  /* 2. Hide the "from £X.XX" price on platform picker cards on mobile */
  .pp-from { display: none !important; }
  .pp-card { padding: 22px 12px !important; }

  /* 3. Estimator — stack the label + value cleanly, not side-by-side */
  .est-label {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }
  .est-label .est-goal {
    font-size: 18px !important;
    line-height: 1.1 !important;
  }
}

/* Mobile — kill the .sheet rounded-corner overlap so sections sit flush */
@media (max-width: 768px) {
  .section.sheet { margin-top: 0 !important; border-radius: 0 !important; }
}

/* Mobile — make the hero card flow seamlessly into the proof section */
@media (max-width: 768px) {
  /* Hero card edge-to-edge: kill side padding so it spans full width */
  .hero-right { padding: 12px 0 0 !important; }
  .hero-card { max-width: 100% !important; margin: 0 !important; border-radius: 20px 20px 0 0 !important; padding-bottom: 28px !important; }
  /* Remove the float pills that overlap on tiny screens */
  .hero-float-1, .hero-float-2 { display: none !important; }

  /* Make the bottom of the hero blend (no clip-path diagonal showing dark below the card) */
  .hero-dark { clip-path: none !important; bottom: auto !important; height: 100% !important; }

  /* Pull the proof section up so it abuts the hero card with no whitespace */
  .proof-section { padding-top: 0 !important; }
  .proof-section .wrap { padding: 0 !important; }
  .proof-big { border-radius: 0 !important; }
  .proof-side { padding: 0 16px !important; margin-top: 12px !important; }
  .proof-grid { gap: 12px !important; }
}

/* Mobile — kill the bg-color change between "Built different" and "Live feed" */
@media (max-width: 768px) {
  .section.sheet.bg-tint.activity { background: transparent !important; padding-top: 24px !important; }
  /* Tighten any whitespace at the boundary */
  .section.sheet.bg-white + .section.sheet.bg-tint.activity { padding-top: 8px !important; }
}

/* ============================================================
   Platform pill selectors — unified clean look
   ============================================================ */

/* Showcase tabs — dark navy active, no more purple gradient */
.showcase-tab {
  background: #fff !important;
  border: 1px solid rgba(12,10,26,0.08) !important;
  color: var(--muted) !important;
  font-weight: 600 !important;
  padding: 10px 18px !important;
  font-size: 13px !important;
  border-radius: 999px !important;
  box-shadow: none !important;
  transition: all .15s !important;
}
.showcase-tab:hover {
  color: var(--ink) !important;
  border-color: rgba(12,10,26,0.2) !important;
}
.showcase-tab.active {
  background: var(--ink) !important;
  color: #fff !important;
  border-color: var(--ink) !important;
  box-shadow: none !important;
}

/* Estimator tabs — tidy up the dark-on-dark pills */
.est-platforms { gap: 6px !important; }
.est-platforms button {
  background: rgba(255,255,255,0.06) !important;
  border: 1px solid rgba(255,255,255,0.1) !important;
  color: rgba(255,255,255,0.7) !important;
  padding: 9px 16px !important;
  border-radius: 999px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  transition: all .15s !important;
}
.est-platforms button:hover {
  background: rgba(255,255,255,0.1) !important;
  color: #fff !important;
}
.est-platforms button.active {
  background: var(--lime, #C3FF36) !important;
  color: var(--ink) !important;
  border-color: var(--lime, #C3FF36) !important;
  box-shadow: 0 6px 18px rgba(195,255,54,0.3) !important;
  font-weight: 700 !important;
}

/* Mobile tweaks */
@media (max-width: 768px) {
  .showcase-tab { padding: 8px 14px !important; font-size: 12.5px !important; }
  .est-platforms button { padding: 8px 14px !important; font-size: 12.5px !important; }
}

/* Platform pill grids — even widths */
.showcase-tabs {
  display: grid !important;
  grid-template-columns: repeat(6, 1fr) !important;
  gap: 7px !important;
  max-width: 760px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.showcase-tab { text-align: center; }

.est-platforms {
  display: grid !important;
  grid-template-columns: repeat(6, 1fr) !important;
  gap: 7px !important;
}
.est-platforms button { text-align: center; }

@media (max-width: 768px) {
  .showcase-tabs { grid-template-columns: repeat(3, 1fr) !important; max-width: 100% !important; gap: 6px !important; }
  .est-platforms { grid-template-columns: repeat(3, 1fr) !important; gap: 6px !important; }
}
@media (max-width: 420px) {
  .showcase-tab { padding: 7px 8px !important; font-size: 11.5px !important; }
  .est-platforms button { padding: 7px 8px !important; font-size: 11.5px !important; }
}

/* Revert proof block back to a contained box style on mobile */
@media (max-width: 768px) {
  .proof-section { padding: 40px 0 !important; }
  .proof-section .wrap { padding: 0 16px !important; }
  .proof-big { border-radius: 22px !important; }
  .proof-side { padding: 0 !important; margin-top: 0 !important; }
  .proof-grid { gap: 12px !important; }
}

/* Mobile — fix the hero → proof flow:
   hero card edge-to-edge, dark proof tile immediately below it (no gap),
   creating a continuous dark→white→dark sandwich. */
@media (max-width: 768px) {
  /* Hero card stretches FULL width, no dark strips on sides */
  .hero-inner { padding-left: 0 !important; padding-right: 0 !important; }
  .hero-left { padding-left: 20px !important; padding-right: 20px !important; }
  .hero-right { padding: 12px 0 0 !important; }
  .hero-card { max-width: 100% !important; width: 100% !important; margin: 0 !important; border-radius: 0 !important; padding-bottom: 24px !important; }

  /* Kill the gap between hero and proof — they butt up against each other */
  .proof-section { padding-top: 0 !important; padding-bottom: 32px !important; }
  .proof-section .wrap { padding: 0 !important; }
  .proof-big { border-radius: 0 !important; }
  .proof-side { padding: 16px 16px 0 !important; }

  /* Subtle separator between the white hero card and the dark proof tile */
  .proof-big { box-shadow: inset 0 1px 0 rgba(255,255,255,0.04) !important; }
}

/* ============================================================
   Mobile polish pass — typography, color, spacing rhythm
   ============================================================ */
@media (max-width: 768px) {
  .announce { padding: 7px 14px !important; font-size: 12px !important; }
  .announce-extra { display: none; }

  /* Hero: reduce CTA gap + bottom padding so card sits closer */
  .hero-cta { gap: 8px !important; margin-bottom: 18px !important; }
  .hero-trust { padding-top: 16px !important; margin-top: 16px !important; }
  .hero-left { padding-bottom: 28px !important; }

  /* Hero card: refine internal styling, neutralize purple */
  .hero-card { padding: 20px !important; }
  .hero-card-head { margin-bottom: 14px !important; gap: 10px !important; }
  .hero-card-av { background: linear-gradient(135deg, #0c0a1a, #4F46E5) !important; }
  .hero-stats { padding: 12px 0 !important; }
  .hero-stat .n { font-size: 18px !important; }
  .hero-stat .l { font-size: 10px !important; }
  .hero-chart { padding-top: 12px !important; }
  .hero-chart-h b { color: #16a34a !important; }
  .showcase-h, .hero-card .eyebrow,
  div[class*="REAL GROWTH"], .hero-card .showcase-h {
    color: var(--ink) !important;
  }

  /* "Real growth looks like this" eyebrow inside hero card */
  .hero-right .eyebrow, .hero-card .eyebrow { color: var(--muted) !important; }

  /* Subtle bottom separator between hero and proof tile */
  .hero { box-shadow: inset 0 -1px 0 rgba(0,0,0,0.15) !important; }

  /* Side cards (10m, 30d): better internal balance */
  .proof-card { padding: 24px 22px !important; gap: 20px !important; }
  .proof-card-n {
    font-size: 42px !important;
    min-width: 80px !important;
    color: var(--ink) !important;
  }
  .proof-card-l b { font-size: 15.5px !important; }
  .proof-card-l { font-size: 13px !important; }

  /* Tighter proof big tile typography */
  .proof-big { padding: 28px 20px 24px !important; }
  .proof-eye { font-size: 10px !important; letter-spacing: 0.14em !important; }
  .proof-huge { font-size: 68px !important; margin: 12px 0 6px !important; }
  .proof-sub { font-size: 17px !important; line-height: 1.25 !important; }
  .proof-foot { padding-top: 18px !important; }

  /* Section header text rhythm */
  .section .h2 { font-size: 30px !important; line-height: 1.08 !important; }
  .section .lead { font-size: 14.5px !important; margin-top: 10px !important; }
  .section .eyebrow { font-size: 10.5px !important; letter-spacing: 0.12em !important; }
  .center { margin-bottom: 28px !important; }

  /* Section breathing room — equal rhythm */
  .section { padding: 48px 0 !important; }
  .section.sheet { padding-top: 48px !important; padding-bottom: 48px !important; }
}

/* Hero card flows seamlessly + 1.2M+ goes back to a contained box */
@media (max-width: 768px) {
  /* Hero card: edge-to-edge with rounded corners on BOTH top and bottom */
  .hero-card {
    border-radius: 20px !important;
    max-width: calc(100% - 24px) !important;
    margin: 0 12px !important;
    padding-bottom: 22px !important;
  }
  .hero-right { padding: 16px 0 28px !important; }

  /* Proof block: contained BOX with rounded corners + side margins again */
  .proof-section { padding: 32px 0 !important; }
  .proof-section .wrap { padding: 0 16px !important; }
  .proof-big { border-radius: 22px !important; }
  .proof-side { padding: 0 !important; margin-top: 0 !important; }
}

/* "Real growth looks like this" eyebrow — center it cleanly with the card below */
@media (max-width: 768px) {
  .hero-right::before {
    text-align: center !important;
    width: 100% !important;
    padding-left: 12px !important;
    padding-right: 12px !important;
    box-sizing: border-box !important;
    margin: 0 auto 18px !important;
    display: block !important;
  }
}

/* More breathing room between the review summary and the white card */
@media (max-width: 768px) {
  .hero-left { padding-bottom: 40px !important; }
  .hero-right { padding-top: 28px !important; }
}

/* A bit more space below the rating row */
@media (max-width: 768px) {
  .hero-left { padding-bottom: 56px !important; }
  .hero-right { padding-top: 36px !important; }
}

/* Vertically center the "REAL GROWTH LOOKS LIKE THIS" eyebrow
   in the white space above the @yourbrand card */
@media (max-width: 768px) {
  .hero-right { padding-top: 28px !important; padding-bottom: 24px !important; }
  .hero-right::before { margin-bottom: 28px !important; }
}


/* Mobile — smooth transition between hero-right's white area and the cream below */
@media (max-width: 768px) {
  .hero-right {
    background: linear-gradient(180deg, #fff 0%, #faf8ff 60%, #f4f3ef 100%) !important;
    padding-bottom: 32px !important;
  }
  .proof-section { padding-top: 28px !important; }
}

/* Mobile — body + proof bg both cream so the fade lands on the same color */
@media (max-width: 768px) {
  body { background: #f4f3ef !important; }
  .proof-section { background: #f4f3ef !important; }
}

/* Mobile — kill the hero-card's heavy purple shadow that creates a visible divider */
@media (max-width: 768px) {
  .hero-card { box-shadow: 0 8px 24px rgba(12,10,26,0.06) !important; }
}


/* ============================================================
   Mobile — kill the seam between hero bottom and proof section
   Hero-right keeps its lavender fade, but ENDS at white.
   Proof section bg is white. No visible boundary.
   ============================================================ */
@media (max-width: 768px) {
  body { background: #fff !important; }
  .hero-right {
    background: linear-gradient(180deg, #fff 0%, #f3eefd 50%, #fff 100%) !important;
    box-shadow: none !important;
  }
  .proof-section { background: #fff !important; }
  .hero { box-shadow: none !important; }
  .hero-card { box-shadow: 0 8px 24px rgba(12,10,26,0.06) !important; }
  .proof-big { box-shadow: none !important; }
}

/* Kill hero-card shadow on mobile — it was casting a faint line below the card */
@media (max-width: 768px) {
  .hero-card { box-shadow: none !important; }
}

/* Mobile — pull proof section up 1px to hide any sub-pixel rendering line at boundary */
@media (max-width: 768px) {
  .proof-section { margin-top: -2px !important; position: relative !important; z-index: 1 !important; }
}

/* Keep the lavender fade visible UNDER the @yourbrand card —
   gradient stays lavender at the bottom, proof section matches */
@media (max-width: 768px) {
  .hero-right {
    background: linear-gradient(180deg, #fff 0%, #f3eefd 65%, #f3eefd 100%) !important;
  }
  .proof-section { background: #f3eefd !important; }
  body { background: #f3eefd !important; }
}

/* Lavender fades into white through the proof section */
@media (max-width: 768px) {
  .proof-section {
    background: linear-gradient(180deg, #f3eefd 0%, #f3eefd 30%, #fff 100%) !important;
  }
  body { background: #fff !important; }
}



/* Restore original logo styles + slim mobile header */
.logo {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -0.03em;
  color: var(--ink);
  text-shadow: none;
  display: flex;
  align-items: center;
  gap: 10px;
}
.logo-mark {
  width: auto;
  height: 32px;
  border-radius: 0;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: none;
}
.logo-mark svg { width: 18px; height: 18px; }
.logo-mark img { height: 100%; width: auto; display: block; }
.logo-mark::before { content: none !important; }

/* Mobile — half height header, properly-built hamburger */
@media (max-width: 768px) {
  .header { padding: 0 12px !important; }
  .header-inner { padding: 4px 6px !important; min-height: 0 !important; gap: 8px !important; }
  .logo { font-size: 15px !important; gap: 8px !important; }
  .logo-mark { width: auto !important; height: 26px !important; border-radius: 0 !important; background: transparent !important; box-shadow: none !important; }
  .logo-mark svg { width: 14px !important; height: 14px !important; }
  .logo-mark img { height: 100% !important; width: auto !important; }

  .header .cart-btn,
  .header .hamburger {
    width: 30px !important;
    height: 30px !important;
    padding: 0 !important;
    border-radius: 8px !important;
    background: #f4f3ef !important;
    border: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: relative !important;
  }
  .header .cart-btn svg { width: 14px !important; height: 14px !important; stroke: #0c0a1a !important; }
  .header .cart-count {
    position: absolute !important;
    top: -3px !important; right: -3px !important;
    background: #0c0a1a !important; color: #fff !important;
    font-size: 9px !important; font-weight: 800 !important;
    min-width: 14px !important; height: 14px !important;
    line-height: 14px !important;
    padding: 0 4px !important;
    border-radius: 999px !important;
    margin: 0 !important;
  }

  /* PROPER hamburger — three even bars, evenly spaced, vertically centered */
  .header .hamburger {
    flex-direction: column !important;
    justify-content: center !important;
    gap: 3px !important;
  }
  .header .hamburger span {
    display: block !important;
    width: 14px !important;
    height: 1.6px !important;
    background: #0c0a1a !important;
    border-radius: 1px !important;
    margin: 0 !important;
  }
}

/* Mobile — make the ENTIRE header much thinner */
@media (max-width: 768px) {
  .header { padding: 0 10px !important; }
  .header-inner { padding: 2px 6px !important; }
  .logo { font-size: 13.5px !important; gap: 6px !important; }
  .logo-mark { width: 20px !important; height: 20px !important; border-radius: 6px !important; box-shadow: none !important; }
  .logo-mark svg { width: 11px !important; height: 11px !important; }

  .header .cart-btn,
  .header .hamburger {
    width: 26px !important;
    height: 26px !important;
    border-radius: 7px !important;
  }
  .header .cart-btn svg { width: 12px !important; height: 12px !important; }
  .header .cart-count {
    font-size: 8px !important;
    min-width: 12px !important; height: 12px !important; line-height: 12px !important;
    padding: 0 3px !important;
  }
  .header .hamburger { gap: 2.5px !important; }
  .header .hamburger span { width: 12px !important; height: 1.4px !important; }
}

/* Reduce gap between hero card and proof tile on mobile */
@media (max-width: 768px) {
  .hero-right { padding-bottom: 14px !important; }
  .proof-section { padding-top: 14px !important; }
}

/* Force the actual header container to shrink, not just its contents */
@media (max-width: 768px) {
  .header-inner {
    min-height: 0 !important;
    padding: 3px 6px !important;
    border-radius: 10px !important;
  }
  .header { padding: 4px 10px 0 !important; }
}

/* Inset hero-right so dark hero bg shows on the sides */
@media (max-width: 768px) {
  .hero-right {
    margin-left: 16px !important;
    margin-right: 16px !important;
    border-radius: 22px !important;
  }
}

/* AGGRESSIVE header shrink + straight-bottom hero card + proof padding */
@media (max-width: 768px) {
  /* Force header container to TINY height */
  .header { padding: 3px 10px 0 !important; }
  .header-inner {
    min-height: 0 !important;
    padding: 2px 4px !important;
    height: auto !important;
    border-radius: 9px !important;
  }
  /* Force ALL button sizes (override base 44x44) */
  .header .cart-btn, .header .hamburger,
  .header-actions .cart-btn, .header-actions .hamburger {
    width: 24px !important;
    height: 24px !important;
    min-width: 0 !important;
    min-height: 0 !important;
    border-radius: 6px !important;
  }
  .header .cart-btn svg { width: 11px !important; height: 11px !important; }
  .header .hamburger span { width: 11px !important; height: 1.3px !important; }
  .header .cart-count {
    top: -2px !important; right: -2px !important;
    font-size: 7.5px !important;
    min-width: 10px !important; height: 10px !important;
    line-height: 10px !important; padding: 0 2px !important;
  }
  .logo { font-size: 13px !important; gap: 6px !important; }
  .logo-mark { width: 18px !important; height: 18px !important; border-radius: 5px !important; }
  .logo-mark svg { width: 10px !important; height: 10px !important; }

  /* Straight bottom on hero card, keep top curved */
  .hero-right {
    border-radius: 22px 22px 0 0 !important;
    margin-bottom: 0 !important;
    padding-bottom: 18px !important;
  }
  /* A bit more padding above the 1.2M+ */
  .proof-section { padding-top: 22px !important; }
}

/* Slight bottom curve + bump header sizing a notch */
@media (max-width: 768px) {
  .hero-right { border-radius: 22px 22px 10px 10px !important; }

  .header { padding: 6px 12px 0 !important; }
  .header-inner { padding: 4px 6px !important; border-radius: 11px !important; }
  .header .cart-btn, .header .hamburger {
    width: 30px !important; height: 30px !important;
    border-radius: 8px !important;
  }
  .header .cart-btn svg { width: 13px !important; height: 13px !important; }
  .header .hamburger span { width: 13px !important; height: 1.5px !important; }
  .header .cart-count {
    font-size: 8.5px !important;
    min-width: 12px !important; height: 12px !important; line-height: 12px !important;
  }
  .logo { font-size: 15px !important; gap: 8px !important; }
  .logo-mark { width: 22px !important; height: 22px !important; border-radius: 6px !important; }
  .logo-mark svg { width: 12px !important; height: 12px !important; }
}

/* Flip the curve direction (bottom rounded, top flatter) + bump header 50% */
@media (max-width: 768px) {
  .hero-right { border-radius: 10px 10px 22px 22px !important; }

  .header { padding: 9px 14px 0 !important; }
  .header-inner { padding: 6px 8px !important; border-radius: 14px !important; }
  .header .cart-btn, .header .hamburger {
    width: 44px !important; height: 44px !important;
    border-radius: 11px !important;
  }
  .header .cart-btn svg { width: 18px !important; height: 18px !important; }
  .header .hamburger { gap: 4px !important; }
  .header .hamburger span { width: 18px !important; height: 2px !important; }
  .header .cart-count {
    font-size: 10px !important;
    min-width: 16px !important; height: 16px !important; line-height: 16px !important;
    top: -4px !important; right: -4px !important; padding: 0 4px !important;
  }
  .logo { font-size: 19px !important; gap: 10px !important; }
  .logo-mark { width: 32px !important; height: 32px !important; border-radius: 9px !important; }
  .logo-mark svg { width: 17px !important; height: 17px !important; }
}

/* Revert curve direction (top rounded, bottom subtle) + outward-curving bottom corners + center header */
@media (max-width: 768px) {
  /* Top rounded, bottom kept subtle; add outward "scoop" corners via pseudo-elements */
  .hero-right {
    border-radius: 22px 22px 0 0 !important;
    position: relative !important;
    padding-bottom: 0 !important;
    margin-bottom: 18px !important;
  }
  .hero-right::after {
    content: '' !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: -16px !important;
    height: 16px !important;
    background:
      radial-gradient(circle 16px at 0 0, transparent 16px, #fff 16px) top left/16px 16px no-repeat,
      radial-gradient(circle 16px at 100% 0, transparent 16px, #fff 16px) top right/16px 16px no-repeat,
      linear-gradient(#fff, #fff) 16px 0/calc(100% - 32px) 100% no-repeat !important;
    pointer-events: none !important;
  }

  /* Header: shift content upward so it's vertically centered properly */
  .header-inner { padding: 4px 8px !important; align-items: center !important; }
  .header { padding: 6px 14px 0 !important; }
}

/* Fix broken outward curve + properly center header content */
@media (max-width: 768px) {
  /* Remove the broken pseudo-element scoop */
  .hero-right::after { display: none !important; }
  .hero-right { margin-bottom: 0 !important; padding-bottom: 18px !important; border-radius: 22px !important; }

  /* Shift header content UP by reducing top padding more than bottom */
  .header-inner { padding: 3px 8px 6px !important; }
  .header { padding: 4px 14px 0 !important; }
}

/* Outward-curving bottom corners on hero-right (horizontally flipped from normal rounded) */
@media (max-width: 768px) {
  .hero-right { border-radius: 22px 22px 0 0 !important; position: relative !important; }
  .hero-right::before,
  .hero-right::after {
    content: '' !important;
    position: absolute !important;
    bottom: 0 !important;
    width: 22px !important;
    height: 22px !important;
    background: transparent !important;
    pointer-events: none !important;
    display: block !important;
  }
  /* Left tab: white area with a transparent quarter-circle cut out of its TOP-RIGHT corner */
  .hero-right::before {
    left: -22px !important;
    background: radial-gradient(circle 22px at 100% 0, transparent 22px, #fff 22.5px) !important;
  }
  /* Right tab: mirrored — transparent quarter-circle cut from its TOP-LEFT */
  .hero-right::after {
    right: -22px !important;
    background: radial-gradient(circle 22px at 0 0, transparent 22px, #fff 22.5px) !important;
  }
}

/* Outward curves — bigger + ensure both sides render */
@media (max-width: 768px) {
  .hero, .hero-inner, .hero-right { overflow: visible !important; }
  .hero-right::before,
  .hero-right::after {
    width: 32px !important;
    height: 32px !important;
  }
  .hero-right::before {
    left: -32px !important;
    background: radial-gradient(circle 32px at 100% 0, transparent 32px, #fff 32.5px) !important;
  }
  .hero-right::after {
    right: -32px !important;
    background: radial-gradient(circle 32px at 0 0, transparent 32px, #fff 32.5px) !important;
  }
}

/* Size outward curves to fit within page margins (16px) */
@media (max-width: 768px) {
  .hero-right::before,
  .hero-right::after {
    width: 16px !important;
    height: 16px !important;
  }
  .hero-right::before {
    left: -16px !important;
    background: radial-gradient(circle 16px at 100% 0, transparent 16px, #fff 16.5px) !important;
  }
  .hero-right::after {
    right: -16px !important;
    background: radial-gradient(circle 16px at 0 0, transparent 16px, #fff 16.5px) !important;
  }
}

/* Revert to old style: dark hero around the entire card, no white area, no outward curves */
@media (max-width: 768px) {
  .hero-right {
    background: transparent !important;
    margin: 0 !important;
    padding: 16px 20px 32px !important;
    border-radius: 0 !important;
  }
  .hero-right::before, .hero-right::after { display: none !important; }
  /* Hero card is the only white thing, sits on dark hero */
  .hero-card {
    max-width: 100% !important;
    margin: 0 auto !important;
    border-radius: 20px !important;
    box-shadow: 0 16px 40px rgba(0,0,0,0.3) !important;
  }
  /* Move the "REAL GROWTH" eyebrow back to being white text on dark */
  .hero-right::before { display: block !important; color: #C3FF36 !important; }
}

/* Reinstate the "Real growth looks like this" eyebrow on dark hero */
@media (max-width: 768px) {
  .hero-right::after { display: none !important; }
  .hero-right::before {
    display: block !important;
    content: 'Real growth looks like this' !important;
    color: #C3FF36 !important;
    text-align: center !important;
    font-family: 'Inter', sans-serif !important;
    font-size: 11px !important;
    font-weight: 800 !important;
    text-transform: uppercase !important;
    letter-spacing: 0.14em !important;
    margin: 0 0 22px !important;
    padding: 0 !important;
    position: static !important;
    width: 100% !important;
    height: auto !important;
    background: none !important;
  }
}

/* Restore: white "hero-right" area around the @yourbrand card, dark hero around the sides */
@media (max-width: 768px) {
  .hero-right {
    background: #fff !important;
    margin: 0 16px !important;
    padding: 28px 22px 32px !important;
    border-radius: 22px !important;
  }
  /* Eyebrow back to purple/dark color on white */
  .hero-right::before {
    color: var(--purple) !important;
  }
  .hero-card {
    box-shadow: 0 8px 24px rgba(12,10,26,0.06) !important;
  }
}

/* Shift white hero-right up — less gap between rating row and the card area */
@media (max-width: 768px) {
  .hero-left { padding-bottom: 24px !important; }
  .hero-right { padding-top: 18px !important; }
  .hero-inner { gap: 0 !important; }
}

/* Add dark background border BELOW the white card too + shift up more */
@media (max-width: 768px) {
  .hero-left { padding-bottom: 16px !important; }
  .hero-right {
    margin-bottom: 18px !important;
    padding-top: 14px !important;
  }
}

/* Vertically center "REAL GROWTH LOOKS LIKE THIS" eyebrow in the white border area */
@media (max-width: 768px) {
  .hero-right { padding-top: 26px !important; }
  .hero-right::before { margin-bottom: 26px !important; }
}

/* Match proof-section top + bottom padding */
@media (max-width: 768px) {
  .proof-section { padding-top: 32px !important; padding-bottom: 32px !important; }
}

/* Match padding below hero card to padding above proof tile */
@media (max-width: 768px) {
  .hero-right { margin-bottom: 32px !important; }
}

/* Hide long "auto-applied at checkout" suffix on mobile */
@media (max-width: 560px) {
  .announce-extra { display: none !important; }
  .announce { font-size: 11px !important; padding: 7px 12px !important; }
}

/* Make body fill the viewport so the footer always sits flush at the bottom */
html { height: 100%; }
body { min-height: 100vh; display: flex; flex-direction: column; }
body > footer.footer { margin-top: auto !important; }
body > footer.site-footer { margin-top: auto !important; }
body { padding-bottom: 0 !important; margin-bottom: 0 !important; }
/* Kill any padding-bottom on product page shell that would push past the footer */
body.pdp-page .pdp-shell { padding-bottom: 24px !important; }

/* Product page: stronger tile shadows so they pop on the darker bg */
body.pdp-page .b-tile {
  box-shadow: 0 6px 18px rgba(12,10,26,0.06), 0 1px 3px rgba(12,10,26,0.04) !important;
  border: 1px solid rgba(12,10,26,0.05) !important;
}

/* Homepage mobile bg → apple grey to match product page */
@media (max-width: 768px) {
  body:not(.pdp-page) { background: #F4F1EB !important; }
  body:not(.pdp-page) .section.sheet.bg-white,
  body:not(.pdp-page) .section.sheet.bg-tint,
  body:not(.pdp-page) .bg-white,
  body:not(.pdp-page) .bg-tint,
  body:not(.pdp-page) .section.sheet { background: transparent !important; }
  body:not(.pdp-page) .hero-right { background: #F4F1EB !important; }
}

/* Header: full-width, logo flush left, cart flush right, nav perfectly centered */
@media (min-width: 769px) {
  .header { padding: 0 !important; }
  .header .wrap.header-inner {
    max-width: none !important;
    padding: 14px 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 0 !important;
    position: relative !important;
  }
  .header .nav {
    position: absolute !important;
    left: 50% !important;
    top: 50% !important;
    transform: translate(-50%, -50%) !important;
  }
  .header .logo { margin-right: auto !important; }
  .header .header-actions { margin-left: auto !important; }
}

/* Header Platforms dropdown */
.nav-dd { position: relative; display: inline-block; }
.nav-dd-trig {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
}
.nav-dd-chev {
  transition: transform .15s;
  opacity: 0.6;
}
.nav-dd:hover .nav-dd-chev,
.nav-dd:focus-within .nav-dd-chev { transform: rotate(180deg); opacity: 1; }
.nav-dd-panel {
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  background: #fff;
  border-radius: 16px;
  padding: 8px;
  width: 280px;
  box-shadow: 0 20px 50px rgba(12,10,26,0.18), 0 0 0 1px rgba(12,10,26,0.05);
  opacity: 0;
  visibility: hidden;
  transition: opacity .15s, transform .15s, visibility .15s;
  z-index: 100;
  margin-top: 12px;
}
.nav-dd:hover .nav-dd-panel,
.nav-dd:focus-within .nav-dd-panel {
  opacity: 1;
  visibility: visible;
  transform: translateX(-50%) translateY(0);
}
/* Invisible hover bridge so the dropdown stays open between trigger and panel */
.nav-dd::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 0;
  right: 0;
  height: 16px;
  pointer-events: none;
}
.nav-dd:hover::after { pointer-events: auto; }

.nav-dd-panel a {
  display: flex !important;
  align-items: center;
  gap: 12px;
  padding: 10px 12px !important;
  border-radius: 11px !important;
  color: var(--ink) !important;
  background: transparent !important;
  font-weight: 500 !important;
  transition: background .15s;
}
.nav-dd-panel a:hover { background: #f4f3ef !important; }
.nav-dd-panel a b {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: -0.01em;
}
.nav-dd-panel a small {
  display: block;
  font-size: 11.5px;
  color: var(--muted);
  font-weight: 500;
  margin-top: 1px;
}
.dd-ico {
  width: 32px; height: 32px;
  border-radius: 9px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  color: #fff;
}
.dd-ico svg { width: 16px; height: 16px; }
.ico-ig{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF)}
.ico-tt{background:#000}
.ico-yt{background:#FF0000}
.ico-sp{background:#1DB954}
.ico-fb{background:#1877F2}
.ico-x{background:#000}

/* Mobile: hide dropdown panel (mobile uses the drawer) */
@media (max-width: 768px) {
  .nav-dd-panel { display: none !important; }
  .nav-dd-chev { display: none !important; }
}

/* ============================================================
   PLATFORM-SPECIFIC THEMING — each product page feels owned
   ============================================================ */

/* Instagram — pink/purple hero + gradient rating */
body.pf-instagram .b-hero { background: linear-gradient(135deg,#0c0a1a 0%,#2d1138 45%,#8134AF 100%) !important; }
body.pf-instagram .b-hero::after { background: radial-gradient(circle,rgba(245,133,41,0.25),transparent 70%) !important; }
body.pf-instagram .b-rating { background: linear-gradient(135deg,#F58529,#DD2A7B 60%,#8134AF) !important; color: #fff !important; }
body.pf-instagram .b-hero h1 em { background: linear-gradient(120deg,#F58529,#DD2A7B) !important; -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important; }

/* TikTok — black + cyan/pink */
body.pf-tiktok .b-hero { background: linear-gradient(135deg,#000 0%,#0c0a1a 50%,#1a3a3a 100%) !important; }
body.pf-tiktok .b-hero::after { background: radial-gradient(circle,rgba(254,44,85,0.3),transparent 70%) !important; }
body.pf-tiktok .b-rating { background: linear-gradient(135deg,#25F4EE 0%,#000 50%,#FE2C55 100%) !important; color: #fff !important; }
body.pf-tiktok .b-hero h1 em { background: linear-gradient(120deg,#25F4EE,#FE2C55) !important; -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important; }

/* YouTube — dark + red */
body.pf-youtube .b-hero { background: linear-gradient(135deg,#0c0a1a 0%,#1d1437 50%,#5a0d0d 100%) !important; }
body.pf-youtube .b-hero::after { background: radial-gradient(circle,rgba(255,0,0,0.3),transparent 70%) !important; }
body.pf-youtube .b-rating { background: #FF0000 !important; color: #fff !important; }
body.pf-youtube .b-hero h1 em { background: linear-gradient(120deg,#FF0000,#FF6B6B) !important; -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important; }

/* Spotify — dark + green */
body.pf-spotify .b-hero { background: linear-gradient(135deg,#0c0a1a 0%,#0e2a1c 50%,#0d4a2e 100%) !important; }
body.pf-spotify .b-hero::after { background: radial-gradient(circle,rgba(29,185,84,0.35),transparent 70%) !important; }
body.pf-spotify .b-rating { background: #1DB954 !important; color: #fff !important; }
body.pf-spotify .b-hero h1 em { background: linear-gradient(120deg,#1DB954,#C3FF36) !important; -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important; }

/* Facebook — dark + blue */
body.pf-facebook .b-hero { background: linear-gradient(135deg,#0c0a1a 0%,#131c3a 50%,#1c4ba3 100%) !important; }
body.pf-facebook .b-hero::after { background: radial-gradient(circle,rgba(24,119,242,0.35),transparent 70%) !important; }
body.pf-facebook .b-rating { background: #1877F2 !important; color: #fff !important; }
body.pf-facebook .b-hero h1 em { background: linear-gradient(120deg,#1877F2,#22D3EE) !important; -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important; }

/* X / Twitter — pure black */
body.pf-twitter .b-hero { background: linear-gradient(135deg,#000 0%,#0c0a1a 50%,#1a1a1a 100%) !important; }
body.pf-twitter .b-hero::after { background: radial-gradient(circle,rgba(255,255,255,0.15),transparent 70%) !important; }
body.pf-twitter .b-rating { background: #000 !important; color: #fff !important; }
body.pf-twitter .b-hero h1 em { background: linear-gradient(120deg,#fff,#a0a0a0) !important; -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important; }

/* Common rating-tile text styles for all branded variants */
body[class*="pf-"] .b-rating .stars { color: #fff !important; }
body[class*="pf-"] .b-rating .b-eyebrow { color: rgba(255,255,255,0.65) !important; }
body[class*="pf-"] .b-rating .sub { color: rgba(255,255,255,0.85) !important; }
body[class*="pf-"] .b-rating .num { color: #fff !important; }

/* Fix: cleaner TikTok rating gradient (cyan → pink, no black middle) */
body.pf-tiktok .b-rating { background: linear-gradient(135deg, #25F4EE 0%, #FE2C55 100%) !important; }

/* Remove the hairline borders on tiles — too visible */
body.pdp-page .b-tile { border: none !important; }
.b-perk { border: none !important; }

/* TikTok rating — darker so white text is readable */
body.pf-tiktok .b-rating { background: linear-gradient(135deg, #0a8a87 0%, #b81e3f 100%) !important; }

/* ============================================================
   HOMEPAGE REDESIGN — match the product page bento language
   Apple-grey bg, white tiles, dark+lime palette, unified rhythm
   ============================================================ */

/* 1. Body bg + remove section bg quilt */
body:not(.pdp-page) {
  background: #F4F1EB !important;
}
body:not(.pdp-page) .section.sheet,
body:not(.pdp-page) .section.sheet.bg-white,
body:not(.pdp-page) .section.sheet.bg-tint,
body:not(.pdp-page) .bg-tint,
body:not(.pdp-page) .bg-white { background: transparent !important; }
body:not(.pdp-page) .section.sheet {
  margin-top: 0 !important;
  border-radius: 0 !important;
  padding: 72px 0 !important;
}
body:not(.pdp-page) .trust-strip + .section.sheet { padding-top: 64px !important; }

/* 2. Unified card/tile styling — same as product page bento */
body:not(.pdp-page) .stat-card,
body:not(.pdp-page) .pp-card,
body:not(.pdp-page) .bento-card,
body:not(.pdp-page) .hiw-card,
body:not(.pdp-page) .rv,
body:not(.pdp-page) .faq-item,
body:not(.pdp-page) .showcase-card {
  background: #fff !important;
  border: none !important;
  border-radius: 24px !important;
  box-shadow: 0 6px 18px rgba(12,10,26,0.06), 0 1px 3px rgba(12,10,26,0.04) !important;
}

/* Stats — dark icon with white icon (matching bento dark-perks) */
body:not(.pdp-page) .stat-card { padding: 32px 24px !important; }
body:not(.pdp-page) .stat-card::before { display: none !important; }
body:not(.pdp-page) .stat-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 14px 32px rgba(12,10,26,0.08) !important;
}
body:not(.pdp-page) .stat-ico {
  width: 46px !important; height: 46px !important;
  border-radius: 13px !important;
  background: #f3eefd !important;
  color: #7C3AED !important;
  box-shadow: none !important;
  margin-bottom: 18px !important;
}
body:not(.pdp-page) .stat-ico svg { stroke: #7C3AED !important; width: 20px !important; height: 20px !important; }
body:not(.pdp-page) .stat-num {
  background: none !important;
  -webkit-text-fill-color: var(--ink) !important;
  color: var(--ink) !important;
  font-family: 'Bricolage Grotesque', sans-serif !important;
  font-size: 42px !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
}
body:not(.pdp-page) .stat-lbl { color: var(--muted) !important; font-size: 11px !important; letter-spacing: 0.12em !important; }

/* Platform picker cards — clean white tiles like product page perks */
body:not(.pdp-page) .pp-card { padding: 28px 18px !important; }
body:not(.pdp-page) .pp-card:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 14px 32px rgba(12,10,26,0.08) !important;
}

/* "Built different" bento cards — match product page perk colors (lavender icons) */
body:not(.pdp-page) .bento-card { padding: 28px !important; }
body:not(.pdp-page) .bento-card.feature {
  background: #fff !important;
  color: var(--ink) !important;
}
body:not(.pdp-page) .bento-card.feature .bento-h,
body:not(.pdp-page) .bento-card.feature .bento-stat { color: var(--ink) !important; -webkit-text-fill-color: var(--ink) !important; }
body:not(.pdp-page) .bento-card.feature .bento-p { color: var(--muted) !important; }
body:not(.pdp-page) .bento-card.dark { background: var(--ink) !important; color: #fff !important; }
body:not(.pdp-page) .bento-card.dark .bento-h { color: #fff !important; }
body:not(.pdp-page) .bento-card.dark .bento-p { color: rgba(255,255,255,0.7) !important; }
body:not(.pdp-page) .bento-card.dark .bento-ico {
  background: rgba(255,255,255,0.1) !important;
  color: #fff !important;
}
body:not(.pdp-page) .bento-card.dark .bento-ico svg { stroke: #fff !important; }
body:not(.pdp-page) .bento-card:not(.dark) .bento-ico {
  background: #f3eefd !important;
  color: #7C3AED !important;
  width: 46px !important; height: 46px !important;
  border-radius: 13px !important;
}
body:not(.pdp-page) .bento-card:not(.dark) .bento-ico svg { stroke: #7C3AED !important; width: 20px !important; height: 20px !important; }
body:not(.pdp-page) .bento-card .bento-stat {
  font-family: 'Bricolage Grotesque', sans-serif !important;
  background: none !important;
  -webkit-text-fill-color: var(--ink) !important;
  color: var(--ink) !important;
}
body:not(.pdp-page) .bento-card.dark .bento-stat { color: #fff !important; -webkit-text-fill-color: #fff !important; }

/* How-it-works step cards — match bento perk style */
body:not(.pdp-page) .hiw-card { padding: 28px !important; text-align: left !important; }
body:not(.pdp-page) .hiw-num {
  background: #f3eefd !important;
  color: #7C3AED !important;
  width: 46px !important; height: 46px !important;
  border-radius: 13px !important;
  margin-bottom: 20px !important;
}
body:not(.pdp-page) .hiw-num span,
body:not(.pdp-page) .hiw-num svg { color: #7C3AED !important; stroke: #7C3AED !important; }
body:not(.pdp-page) .hiw-num span { display: none !important; }
body:not(.pdp-page) .hiw-num svg { width: 20px !important; height: 20px !important; display: block !important; }
body:not(.pdp-page) .hiw-step {
  font-size: 11px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.12em !important;
  color: var(--muted) !important;
  font-weight: 700 !important;
}
body:not(.pdp-page) .hiw-h { color: var(--ink) !important; font-family: 'Bricolage Grotesque', sans-serif !important; text-align: left !important; margin-top: 4px !important; }
body:not(.pdp-page) .hiw-p { text-align: left !important; }

/* Reviews — clean white tiles, amber stars, dark badge */
body:not(.pdp-page) .rv { padding: 28px !important; }
body:not(.pdp-page) .rv-stars, body:not(.pdp-page) .rv .rv-stars { color: #FACC15 !important; }
body:not(.pdp-page) .rv-badge { background: var(--ink) !important; color: #fff !important; font-weight: 700 !important; }

/* FAQ */
body:not(.pdp-page) .faq-item { padding: 4px 0 !important; }

/* Section headlines — consistent eyebrow + h2 + lead */
body:not(.pdp-page) .section .center { margin-bottom: 40px !important; }
body:not(.pdp-page) .section .center .eyebrow,
body:not(.pdp-page) .section .eyebrow {
  font-size: 11px !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--muted) !important;
  font-weight: 700 !important;
  background: none !important;
  padding: 0 !important;
}
body:not(.pdp-page) .section .center h2,
body:not(.pdp-page) .section .h2 {
  font-family: 'Bricolage Grotesque', sans-serif !important;
  font-size: clamp(36px, 5vw, 56px) !important;
  font-weight: 800 !important;
  letter-spacing: -0.03em !important;
  line-height: 1.05 !important;
  color: var(--ink) !important;
}

/* Buttons — dark navy primary, lime CTA */
body:not(.pdp-page) .btn-primary {
  background: var(--ink) !important;
  color: #fff !important;
  box-shadow: 0 8px 22px rgba(12,10,26,0.18) !important;
}
body:not(.pdp-page) .btn-primary:hover { transform: translateY(-1px) !important; }

/* Trust strip cleanup */
body:not(.pdp-page) .trust-strip { padding: 16px 0 !important; }
body:not(.pdp-page) .trust-strip .trust-row {
  background: #fff !important;
  border: none !important;
  border-radius: 16px !important;
  box-shadow: 0 6px 18px rgba(12,10,26,0.06) !important;
  padding: 14px 28px !important;
}
body:not(.pdp-page) .trust-strip .trust-item { color: var(--ink) !important; font-weight: 600 !important; }
body:not(.pdp-page) .trust-strip .trust-item svg { stroke: var(--ink) !important; filter: none !important; }
body:not(.pdp-page) .trust-strip .trust-sep { background: rgba(12,10,26,0.1) !important; }

/* Hero chart — replace purple line with cyan */
body:not(.pdp-page) .hc-chart svg path[stroke="#7C3AED"] { stroke: #22D3EE !important; }
body:not(.pdp-page) .hc-chart svg path[fill*="#7C3AED"],
body:not(.pdp-page) .hc-chart svg path[fill="url(#hcg)"] { fill: rgba(34,211,238,0.15) !important; }
body:not(.pdp-page) .hc-chart .v,
body:not(.pdp-page) .hc-chart .v small { color: #16a34a !important; }

/* Showcase — dark navy active tab */
body:not(.pdp-page) .showcase-tab {
  background: #fff !important;
  border: 1px solid rgba(12,10,26,0.06) !important;
  color: var(--muted) !important;
  font-weight: 600 !important;
}
body:not(.pdp-page) .showcase-tab.active {
  background: var(--ink) !important;
  color: #fff !important;
  border-color: var(--ink) !important;
}
body:not(.pdp-page) .showcase-card-head .badge {
  background: var(--ink) !important;
  color: #fff !important;
}
body:not(.pdp-page) .showcase-checks .tick {
  background: #f3eefd !important;
  color: #7C3AED !important;
}

/* Final CTA — dark navy with lime CTA, full-bleed */
body:not(.pdp-page) .final-cta {
  background: var(--ink) !important;
  margin: 60px 24px !important;
  border-radius: 32px !important;
  padding: 80px 40px !important;
}
body:not(.pdp-page) .final-cta .hero-orb { display: none !important; }
body:not(.pdp-page) .final-cta h2 { color: #fff !important; }
body:not(.pdp-page) .final-cta h2 span,
body:not(.pdp-page) .final-cta h2 .grad {
  background: linear-gradient(120deg, #fff 0%, #C3FF36 100%) !important;
  -webkit-background-clip: text !important;
  background-clip: text !important;
  color: transparent !important;
}
body:not(.pdp-page) .final-cta p { color: rgba(255,255,255,0.7) !important; }
body:not(.pdp-page) .final-cta .btn-primary {
  background: #C3FF36 !important;
  color: var(--ink) !important;
  box-shadow: 0 10px 28px rgba(195,255,54,0.3) !important;
}

/* Estimator section — dark navy floating tile */
body:not(.pdp-page) .section.sheet.bg-dark.estimator {
  background: var(--ink) !important;
  margin: 0 24px !important;
  border-radius: 32px !important;
  padding: 60px 40px !important;
}
body:not(.pdp-page) .estimator .hero-orb { display: none !important; }

/* Activity feed card */
body:not(.pdp-page) .activity-feed,
body:not(.pdp-page) .activity-card {
  background: #fff !important;
  border-radius: 24px !important;
  box-shadow: 0 6px 18px rgba(12,10,26,0.06) !important;
  border: none !important;
}




/* ============================================
   SITE FOOTER (.site-footer) — split dark + lime
   ============================================ */
.site-footer { margin-top: 56px; }
@media (max-width: 768px) { .site-footer { margin-top: 36px !important; } }
.sf-split {
  display: grid;
  grid-template-columns: 1.3fr 1fr;
  min-height: 360px;
}
.sf-left {
  background: #0c0a1a;
  color: #fff;
  padding: 56px 56px 40px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
}
.sf-left::before {
  content: '';
  position: absolute;
  top: -50%; left: -10%;
  width: 60%; height: 200%;
  background: radial-gradient(closest-side, rgba(79,70,229,0.18), transparent 70%);
  pointer-events: none;
}
.sf-left > * { position: relative; z-index: 1; }
.sf-headline {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: clamp(28px, 3vw, 40px);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.05;
  color: #fff;
  max-width: 540px;
  margin-bottom: 40px;
}
.sf-headline em {
  font-style: normal;
  background: linear-gradient(120deg, #C3FF36, #22D3EE);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.sf-cols-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 28px;
  margin-bottom: 32px;
}
.sf-col { display: flex; flex-direction: column; gap: 10px; }
.sf-col h4 {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 700;
  color: rgba(195,255,54,0.85);
  margin-bottom: 4px;
}
.sf-col a {
  color: rgba(255,255,255,0.65);
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  transition: color .15s;
}
.sf-col a:hover { color: #fff; }
.sf-copy {
  font-size: 11.5px;
  color: rgba(255,255,255,0.4);
  padding-top: 20px;
  border-top: 1px solid rgba(255,255,255,0.08);
}

.sf-right {
  background: #C3FF36;
  color: #0c0a1a;
  padding: 56px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
}
.sf-right::before {
  content: '';
  position: absolute;
  bottom: -40%; right: -10%;
  width: 60%; height: 180%;
  background: radial-gradient(closest-side, rgba(255,255,255,0.35), transparent 70%);
  pointer-events: none;
}
.sf-right > * { position: relative; z-index: 1; }
.sf-news-eyebrow {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 800;
  color: rgba(12,10,26,0.55);
  margin-bottom: 10px;
}
.sf-news-title {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.1;
  color: #0c0a1a;
}
.sf-news-sub {
  font-size: 14px;
  margin-top: 10px;
  color: rgba(12,10,26,0.7);
  line-height: 1.55;
  max-width: 380px;
}
.sf-news-form {
  display: flex;
  gap: 6px;
  background: rgba(255,255,255,0.55);
  border-radius: 12px;
  padding: 5px;
  margin-top: 24px;
}
.sf-news-form input {
  flex: 1;
  border: 0;
  background: transparent;
  padding: 12px 14px;
  font-size: 14.5px;
  font-family: inherit;
  outline: none;
  min-width: 0;
  color: #0c0a1a;
}
.sf-news-form input::placeholder { color: rgba(12,10,26,0.5); }
.sf-news-form button {
  background: #0c0a1a;
  color: #fff;
  border: 0;
  padding: 12px 20px;
  border-radius: 9px;
  font-weight: 700;
  font-size: 13.5px;
  cursor: pointer;
  font-family: inherit;
  transition: transform .15s;
}
.sf-news-form button:hover { transform: translateY(-1px); }
.sf-news-msg {
  font-size: 12.5px;
  color: #0c0a1a;
  font-weight: 700;
  margin-top: 10px;
}
.sf-news-msg:empty { display: none; }
.sf-right-meta {
  font-size: 11.5px;
  color: rgba(12,10,26,0.5);
  padding-top: 20px;
  border-top: 1px solid rgba(12,10,26,0.12);
}

/* Responsive */
@media (max-width: 1100px) {
  .sf-split { grid-template-columns: 1fr; min-height: auto; }
  .sf-left { padding: 44px 40px 32px; }
  .sf-right { padding: 44px 40px; }
}
@media (max-width: 768px) {
  html, body { background: #0c0a1a; }
  body { margin-bottom: 0; }

  /* Whole footer = single dark column */
  .sf-split { display: flex; flex-direction: column; background: #0c0a1a; }

  /* Newsletter: still in dark, with lime accent */
  .sf-right { background: #0c0a1a; color: #fff; padding: 26px 22px 22px; order: -1; }
  .sf-right::before { display: none; }
  .sf-news-eyebrow { font-size: 11px; color: rgba(195,255,54,0.85); margin-bottom: 8px; }
  .sf-news-title { font-size: 22px; color: #fff; }
  .sf-news-sub { display: none; }
  .sf-news-form {
    margin-top: 14px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 12px;
    padding: 5px;
  }
  .sf-news-form input { background: transparent; color: #fff; padding: 9px 12px; font-size: 13.5px; }
  .sf-news-form input::placeholder { color: rgba(255,255,255,0.45); }
  .sf-news-form button { background: #C3FF36; color: #0c0a1a; padding: 9px 14px; font-size: 12.5px; border-radius: 9px; }
  .sf-news-msg { color: #C3FF36; }
  .sf-right-meta { display: none; }

  /* Dark accordion section */
  .sf-left { padding: 0; background: #0c0a1a; }
  .sf-left::before { display: none; }
  .sf-headline { display: none; }
  .sf-left > div { display: contents; }

  /* Cols become accordion items — top border separator */
  .sf-cols-row { display: block; margin-bottom: 0; gap: 0; padding: 0; border-top: 1px solid rgba(255,255,255,0.08); }
  .sf-col { display: block; border-bottom: 1px solid rgba(255,255,255,0.06); padding: 0; gap: 0; }
  .sf-col h4 {
    margin: 0; padding: 16px 22px;
    display: flex; align-items: center; justify-content: space-between;
    font-size: 14px; font-weight: 700; letter-spacing: -0.005em;
    text-transform: none; color: #fff;
    cursor: pointer;
  }
  .sf-col h4::after {
    content: '';
    width: 9px; height: 9px;
    border-right: 1.75px solid rgba(255,255,255,0.55);
    border-bottom: 1.75px solid rgba(255,255,255,0.55);
    transform: rotate(45deg);
    transform-origin: center;
    margin-right: 6px;
    margin-top: -4px;
    transition: transform .2s ease, border-color .2s ease;
  }
  .sf-col.open h4::after {
    transform: rotate(-135deg);
    margin-top: 2px;
    border-color: #fff;
  }
  .sf-col a {
    display: none;
    padding: 8px 22px;
    font-size: 13.5px;
    color: rgba(255,255,255,0.65);
  }
  .sf-col.open a { display: block; }
  .sf-col.open a:last-of-type { padding-bottom: 16px; }

  /* First column open by default to match mockup */
  .sf-col:first-child { /* default open via class added by JS */ }

  /* Copyright */
  .sf-copy {
    padding: 18px 22px;
    padding-bottom: max(18px, env(safe-area-inset-bottom));
    border-top: none;
    font-size: 11px;
    color: rgba(255,255,255,0.4);
    text-align: center;
    line-height: 1.55;
  }
}


/* ============================================
   SECTION HEADLINES — V8 (centered with rules)
   Applied across home, about, blog, contact, faq
   ============================================ */
.h-headline, .ab-headline, .bl-headline, .ct-headline, .faq-headline {
  text-align: center;
  padding: 64px 24px 32px !important;
}
.h-headline-eyebrow, .ab-headline-eyebrow, .bl-headline-eyebrow, .ct-headline-eyebrow, .faq-headline-eyebrow {
  display: inline-flex !important;
  align-items: center;
  gap: 14px;
  justify-content: center;
  margin: 0 auto 16px !important;
}
.h-headline-eyebrow::before,
.ab-headline-eyebrow::before,
.bl-headline-eyebrow::before,
.ct-headline-eyebrow::before,
.faq-headline-eyebrow::before {
  content: '';
  width: 40px !important;
  height: 1px;
  background: #0c0a1a;
  opacity: 0.4;
}
.h-headline-eyebrow::after,
.ab-headline-eyebrow::after,
.bl-headline-eyebrow::after,
.ct-headline-eyebrow::after,
.faq-headline-eyebrow::after {
  content: '';
  width: 40px;
  height: 1px;
  background: #0c0a1a;
  opacity: 0.4;
}
.h-headline h2, .ab-headline h2, .bl-headline h2, .ct-headline h2, .faq-headline h2 {
  max-width: none !important;
  margin: 0 auto !important;
}
.h-headline p, .ab-headline p, .bl-headline p, .ct-headline p, .faq-headline p {
  margin: 14px auto 0 !important;
  max-width: 540px;
}
@media (max-width: 768px) {
  .h-headline, .ab-headline, .bl-headline, .ct-headline, .faq-headline {
    padding: 36px 14px 18px !important;
  }
  .h-headline-eyebrow::before, .ab-headline-eyebrow::before, .bl-headline-eyebrow::before,
  .ct-headline-eyebrow::before, .faq-headline-eyebrow::before,
  .h-headline-eyebrow::after, .ab-headline-eyebrow::after, .bl-headline-eyebrow::after,
  .ct-headline-eyebrow::after, .faq-headline-eyebrow::after {
    width: 26px !important;
  }
}


/* ============================================================
   FOOTER PLATFORM THEMING — recolor .site-footer per product
   ============================================================ */

/* INSTAGRAM — orange → pink → purple */
body.pf-instagram .sf-right {
  background: linear-gradient(135deg, #F58529 0%, #DD2A7B 50%, #8134AF 100%) !important;
}
body.pf-instagram .sf-headline em {
  background: linear-gradient(120deg, #F58529, #DD2A7B, #8134AF) !important;
  -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important;
}
body.pf-instagram .sf-col h4 { color: #F58529 !important; }
body.pf-instagram .sf-news-form button {
  background: #0c0a1a !important; color: #fff !important;
}

/* TIKTOK — cyan + red over black */
body.pf-tiktok .sf-right {
  background: linear-gradient(135deg, #25F4EE 0%, #161616 55%, #FE2C55 100%) !important;
}
body.pf-tiktok .sf-headline em {
  background: linear-gradient(120deg, #25F4EE, #FE2C55) !important;
  -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important;
}
body.pf-tiktok .sf-col h4 { color: #FE2C55 !important; }
body.pf-tiktok .sf-news-form button {
  background: #FE2C55 !important; color: #fff !important;
}

/* YOUTUBE — red */
body.pf-youtube .sf-right {
  background: linear-gradient(135deg, #FF4B4B 0%, #C4302B 60%, #800000 100%) !important;
}
body.pf-youtube .sf-headline em {
  background: linear-gradient(120deg, #FF4B4B, #C4302B) !important;
  -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important;
}
body.pf-youtube .sf-col h4 { color: #FF4B4B !important; }
body.pf-youtube .sf-news-form button {
  background: #FF0000 !important; color: #fff !important;
}

/* SPOTIFY — green */
body.pf-spotify .sf-right {
  background: linear-gradient(135deg, #1ED760 0%, #0F8A3F 100%) !important;
}
body.pf-spotify .sf-headline em {
  background: linear-gradient(120deg, #1ED760, #0F8A3F) !important;
  -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important;
}
body.pf-spotify .sf-col h4 { color: #1ED760 !important; }
body.pf-spotify .sf-news-form button {
  background: #0c0a1a !important; color: #1ED760 !important;
}

/* FACEBOOK — blue */
body.pf-facebook .sf-right {
  background: linear-gradient(135deg, #2D88FF 0%, #1877F2 55%, #0B5FCC 100%) !important;
}
body.pf-facebook .sf-headline em {
  background: linear-gradient(120deg, #2D88FF, #1877F2) !important;
  -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important;
}
body.pf-facebook .sf-col h4 { color: #2D88FF !important; }
body.pf-facebook .sf-news-form button {
  background: #0c0a1a !important; color: #fff !important;
}

/* X / TWITTER — black with white accent */
body.pf-twitter .sf-right {
  background: linear-gradient(135deg, #2a2a2a 0%, #000 100%) !important;
  color: #fff !important;
}
body.pf-twitter .sf-headline em {
  background: linear-gradient(120deg, #fff, #aaa) !important;
  -webkit-background-clip: text !important; background-clip: text !important; color: transparent !important;
}
body.pf-twitter .sf-col h4 { color: #fff !important; }
body.pf-twitter .sf-news-form button {
  background: #fff !important; color: #000 !important;
}
body.pf-twitter .sf-news-eyebrow { color: rgba(255,255,255,0.5) !important; }
body.pf-twitter .sf-news-title { color: #fff !important; }
body.pf-twitter .sf-news-sub { color: rgba(255,255,255,0.65) !important; }
body.pf-twitter .sf-right-meta { color: rgba(255,255,255,0.55) !important; }

/* Shared: keep right-side text legible against new backgrounds */
body[class*="pf-"]:not(.pf-twitter) .sf-news-eyebrow { color: rgba(255,255,255,0.55) !important; }
body[class*="pf-"]:not(.pf-twitter) .sf-news-title { color: #fff !important; }
body[class*="pf-"]:not(.pf-twitter) .sf-news-sub { color: rgba(255,255,255,0.7) !important; }
body[class*="pf-"]:not(.pf-twitter) .sf-news-form {
  background: rgba(255,255,255,0.18) !important;
  border-color: rgba(255,255,255,0.25) !important;
}
body[class*="pf-"]:not(.pf-twitter) .sf-news-form input { color: #fff !important; }
body[class*="pf-"]:not(.pf-twitter) .sf-news-form input::placeholder { color: rgba(255,255,255,0.6) !important; }
body[class*="pf-"]:not(.pf-twitter) .sf-news-msg { color: #fff !important; }
body[class*="pf-"]:not(.pf-twitter) .sf-right-meta { color: rgba(255,255,255,0.75) !important; }

/* =============================================================
   PRODUCT PAGE — formatting improvements (applies to all PDPs)
   Specificity bumped with body.pdp-page to beat inline <style>
   ============================================================= */

/* FAQ accordion: replace '+' circle with clean chevron */
body.pdp-page .b-faq-plus {
  background: transparent !important;
  border: 1px solid #ece9f4 !important;
  font-size: 0 !important;
  color: transparent !important;
  position: relative;
  overflow: hidden;
}
body.pdp-page .b-faq-plus::before {
  content: '';
  position: absolute;
  top: 50%; left: 50%;
  width: 7px; height: 7px;
  margin: -6px 0 0 -4px;
  border-right: 1.75px solid #0c0a1a;
  border-bottom: 1.75px solid #0c0a1a;
  transform: rotate(45deg);
  transition: transform .2s ease, border-color .2s ease, margin .2s ease;
}
body.pdp-page .b-faq-item.open .b-faq-plus {
  transform: none !important;
  background: #0c0a1a !important;
  border-color: #0c0a1a !important;
}
body.pdp-page .b-faq-item.open .b-faq-plus::before {
  border-color: #fff;
  transform: rotate(-135deg);
  margin: -2px 0 0 -4px;
}
body.pdp-page .b-faq-item.open .b-faq-a { max-height: 600px !important; }

/* Rating/Live tiles: center all content as one tight group (no gaps) */
body.pdp-page .b-rating,
body.pdp-page .b-live {
  min-height: 0 !important;
  justify-content: center !important;
  gap: 0 !important;
  padding: 28px 30px !important;
}
body.pdp-page .b-rating .b-eyebrow,
body.pdp-page .b-live .b-eyebrow { margin-bottom: 16px; font-size: 13px !important; font-weight: 800 !important; }
body.pdp-page .b-rating .num,
body.pdp-page .b-live .num { margin-top: 0 !important; }

/* Beefier rating tile: bigger 4.9 with /5 context, golden stars, bolder sub */
body.pdp-page .b-rating .num {
  font-size: 80px !important;
  line-height: 0.9 !important;
  letter-spacing: -0.04em !important;
}
body.pdp-page .b-rating .stars {
  font-size: 17px !important;
  letter-spacing: 3px !important;
  margin-top: 10px !important;
  color: #fff !important;
}
body.pdp-page .b-rating .sub {
  font-size: 14.5px !important; margin-top: 16px !important;
  padding-top: 0 !important; font-weight: 600 !important;
  color: rgba(255,255,255,0.95) !important;
}
body.pdp-page .b-live .num {
  font-size: 72px !important;
  line-height: 0.95 !important;
  letter-spacing: -0.035em !important;
}
body.pdp-page .b-live .sub {
  font-size: 15px !important; margin-top: 16px !important;
  padding-top: 0 !important; font-weight: 600 !important;
  color: rgba(255,255,255,0.9) !important;
  line-height: 1.4 !important;
}

/* Package card tier distinction — applies on all viewports
   Scoped to :not(.selected) so the selected-state styles take over when clicked */
body.pdp-page #pdp-packages .pkg-card--popular:not(.selected) {
  border-color: #fbd4c2 !important;
  background: linear-gradient(180deg, #fff7f1 0%, #fff 70%) !important;
}
body.pdp-page #pdp-packages .pkg-card--best-value:not(.selected) {
  border-color: #0c0a1a !important;
  border-width: 2px !important;
  background: #fff !important;
  box-shadow: 0 6px 22px rgba(12, 10, 26, 0.08);
}
body.pdp-page #pdp-packages .pkg-card--best-value:not(.selected) .pkg-badge {
  background: #0c0a1a !important;
  color: #C3FF36 !important;
}
/* When a tiered card IS selected, make sure the badge stays readable on dark bg */
body.pdp-page #pdp-packages .pkg-card.selected .pkg-badge {
  background: #C3FF36 !important;
  color: #0c0a1a !important;
}

/* Mobile only: compact package cards + 2-col perks grid */
@media (max-width: 768px) {
  /* Rating/Live tiles: even tighter padding on mobile, no min-height stretch */
  body.pdp-page .b-rating,
  body.pdp-page .b-live {
    padding: 30px 24px !important;
    gap: 8px;
  }
  body.pdp-page .b-rating .num { margin-top: 6px; font-size: 62px !important; }
  body.pdp-page .b-live .num { margin-top: 6px; font-size: 52px !important; }
  body.pdp-page .b-rating .stars { margin-top: 8px !important; font-size: 15px !important; }
  body.pdp-page .b-rating .sub,
  body.pdp-page .b-live .sub { margin-top: 14px !important; padding-top: 0 !important; }

  /* Package cards: horizontal row layout (qty left, price right) */
  body.pdp-page #pdp-packages .pkg-card {
    padding: 16px 18px !important;
  }
  body.pdp-page #pdp-packages .pkg-card-top {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 14px !important;
    margin-bottom: 0 !important;
  }
  body.pdp-page #pdp-packages .pkg-card-qty {
    font-size: 20px !important;
    line-height: 1.1 !important;
    flex: 1; min-width: 0;
  }
  body.pdp-page #pdp-packages .pkg-card-qty span {
    display: inline-block !important;
    font-size: 10px !important;
    margin: 0 0 0 8px !important;
    letter-spacing: 0.1em !important;
    vertical-align: 2px;
    color: #9a96ad !important;
  }
  body.pdp-page #pdp-packages .pkg-card.selected .pkg-card-qty span { color: rgba(255,255,255,0.55) !important; }
  body.pdp-page #pdp-packages .pkg-card-price {
    margin-top: 0 !important;
    font-size: 18px !important;
    text-align: right !important;
    white-space: nowrap;
    flex-shrink: 0;
    display: flex;
    align-items: baseline;
    gap: 8px;
  }
  body.pdp-page #pdp-packages .pkg-card-price small {
    display: inline !important;
    margin-right: 0 !important;
    font-size: 11px !important;
  }
  body.pdp-page #pdp-packages .pkg-badge {
    top: -8px !important;
    left: 14px !important;
    font-size: 8.5px !important;
    padding: 3px 9px !important;
  }

  /* Perks: 2-col grid with icons visible (more compact) */
  body.pdp-page .b-perks {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
    flex-direction: unset !important;
  }
  body.pdp-page .b-perk {
    padding: 18px 16px !important;
    gap: 10px !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    border-radius: 18px !important;
  }
  body.pdp-page .b-perk-ico {
    display: flex !important;
    width: 36px !important; height: 36px !important;
    border-radius: 10px !important;
    background: linear-gradient(135deg, #F97316, #DB2777) !important;
    color: #fff !important;
  }
  body.pdp-page .b-perk-ico svg { width: 16px !important; height: 16px !important; stroke: #fff !important; }
  body.pdp-page .b-perk-t {
    font-family: 'Bricolage Grotesque', sans-serif !important;
    font-size: 15px !important;
    font-weight: 800 !important;
    letter-spacing: -0.015em !important;
    line-height: 1.1 !important;
    margin-bottom: 4px !important;
  }
  body.pdp-page .b-perk-d {
    font-size: 12.5px !important;
    line-height: 1.4 !important;
    color: #6f6b85 !important;
  }
}
