/* ============================================================
   Bump to Baby — marketing site
   Design system
   ============================================================ */

:root{
  /* brand */
  --brand:        #EC6D7A;   /* AppConstants.brandColour */
  --brand-deep:   #d6336c;   /* deeper raspberry for emphasis */
  --brand-soft:   #f6a9b1;

  /* surfaces */
  --peach:        #FFEFE4;   /* app background */
  --peach-deep:   #ffe2cf;
  --cream:        #fff8f2;
  --white:        #ffffff;

  /* ink */
  --ink:          #3a3033;
  --ink-soft:     #8a7a7c;
  --ink-faint:    #b7a8a9;
  --hairline:     rgba(58,48,51,.10);

  /* hero gradient (sampled from App Store art) */
  --hero-grad: linear-gradient(157deg,#f0708a 0%, #f17b78 46%, #f68d57 78%, #f89a4d 100%);

  /* type */
  --f-logo:    'Marcellus', Georgia, serif;
  --f-display: 'Oswald', 'Arial Narrow', sans-serif;
  --f-script:  'Caveat', 'Segoe Script', cursive;
  --f-body:    'Mulish', system-ui, sans-serif;

  /* shadows */
  --sh-sm: 0 2px 8px rgba(120,60,60,.08);
  --sh-md: 0 10px 30px rgba(150,70,70,.13);
  --sh-lg: 0 26px 60px rgba(150,70,70,.20);
  --sh-card: 0 14px 36px rgba(120,55,60,.16);

  /* layout */
  --maxw: 1200px;
  --radius: 26px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--peach);
  line-height:1.62;
  font-size:18px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }

/* ---------- typography helpers ---------- */
.logo{
  font-family:var(--f-logo);
  font-weight:500;
  color:var(--brand);
  letter-spacing:.01em;
  line-height:1;
}
.brand-lockup{ display:inline-flex; align-items:center; gap:.5em; }
.brand-icon{
  width:1.55em; height:1.55em; border-radius:.34em; flex:none;
  background:var(--brand); padding:.1em; object-fit:contain;
}
.script{
  font-family:var(--f-script);
  font-weight:600;
  line-height:1;
}
.kicker{
  font-family:var(--f-display);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.18em;
  font-size:.78rem;
  color:var(--brand);
}
.display{
  font-family:var(--f-display);
  font-weight:700;
  text-transform:uppercase;
  line-height:.98;
  letter-spacing:.005em;
  margin:0;
}
.eyebrow-script{
  font-family:var(--f-script);
  font-size:2rem;
  color:var(--ink);
  line-height:1;
}

h2.display{ font-size:clamp(2.3rem,4.6vw,3.7rem); }
h3.display{ font-size:clamp(1.5rem,2.4vw,2rem); }

.lead{ font-size:1.12rem; color:var(--ink-soft); max-width:46ch; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--f-display); text-transform:uppercase;
  font-weight:600; letter-spacing:.08em; font-size:.95rem;
  padding:.95em 1.7em; border-radius:999px; border:none;
  cursor:pointer; transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  white-space:nowrap;
}
.btn-primary{ background:var(--brand); color:#fff; box-shadow:0 10px 24px rgba(236,109,122,.4); }
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 16px 32px rgba(236,109,122,.5); }
.btn-ghost{ background:rgba(255,255,255,.85); color:var(--brand); box-shadow:var(--sh-sm); }
.btn-ghost:hover{ transform:translateY(-2px); background:#fff; }
.btn-white{ background:#fff; color:var(--brand); box-shadow:var(--sh-md); }
.btn-white:hover{ transform:translateY(-2px); }

/* App Store badge */
.appstore{
  display:inline-flex; align-items:center; gap:.7em;
  background:#1a1416; color:#fff; border-radius:15px;
  padding:.62em 1.25em .68em; transition:transform .18s ease, box-shadow .18s ease;
  box-shadow:0 12px 26px rgba(40,20,25,.28);
}
.appstore:hover{ transform:translateY(-2px); box-shadow:0 18px 34px rgba(40,20,25,.36); }
.appstore svg{ width:30px; height:30px; flex:none; }
.appstore .as-top{ display:block; font-size:.66rem; letter-spacing:.04em; opacity:.85; line-height:1.1; text-transform:none; font-family:var(--f-body); }
.appstore .as-big{ display:block; font-size:1.32rem; font-weight:600; line-height:1.05; font-family:var(--f-body); letter-spacing:.01em; }

/* ---------- nav ---------- */
header.nav{
  position:fixed; top:0; left:0; right:0; z-index:60;
  transition:background .3s ease, box-shadow .3s ease, padding .3s ease;
  padding:18px 0;
}
header.nav.scrolled{
  background:rgba(255,239,228,.92);
  backdrop-filter:blur(14px);
  box-shadow:0 4px 24px rgba(150,80,80,.10);
  padding:11px 0;
}
.nav-inner{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.nav .logo{ font-size:1.7rem; color:#fff; transition:color .3s ease; }
header.nav.scrolled .logo{ color:var(--brand); }
.nav-links{ display:flex; align-items:center; gap:30px; }
.nav-links a{
  font-family:var(--f-display); text-transform:uppercase; letter-spacing:.12em;
  font-size:.82rem; font-weight:500; color:#fff; opacity:.92; transition:opacity .2s, color .3s;
}
header.nav.scrolled .nav-links a{ color:var(--ink); }
header.nav.scrolled .nav-links a.nav-cta{ color:#fff; }
.nav-links a:hover{ opacity:1; }
.nav-cta{ font-size:.82rem !important; background:#D6336C; box-shadow:0 10px 24px rgba(214,51,108,.4); }
.nav-cta:hover{ background:#c02b60; box-shadow:0 16px 32px rgba(214,51,108,.5); }
.nav-toggle{ display:none; background:none; border:none; cursor:pointer; padding:6px; }
.nav-toggle span{ display:block; width:24px; height:2.4px; background:#fff; margin:5px 0; border-radius:2px; transition:.3s; }
header.nav.scrolled .nav-toggle span{ background:var(--brand); }

/* ---------- hero ---------- */
.hero{
  position:relative; background:var(--hero-grad); color:#fff;
  padding:150px 0 90px; overflow:hidden;
}
.hero-inner{ display:grid; grid-template-columns:1.05fr .95fr; gap:40px; align-items:center; }
.hero-brand{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase; color:#fff; margin:0 0 10px;
  font-size:clamp(3.2rem,7vw,5.6rem); line-height:.95; letter-spacing:.01em;
  text-shadow:0 1px 1px rgba(150,40,60,.22), 0 4px 26px rgba(120,30,50,.26);
}
.hero-headline{
  font-family:var(--f-script); text-transform:none; font-weight:600;
  font-size:clamp(1.7rem,3.3vw,2.7rem); letter-spacing:.01em; line-height:1.05;
  color:#fff; margin:0 0 16px; opacity:.98;
}
.nav-mark .brand-icon{ width:42px; height:42px; border-radius:12px; }
/* nav brand mark: hidden at top, fades in once scrolled */
.nav-mark{ opacity:0; visibility:hidden; pointer-events:none; transition:opacity .3s ease, visibility .3s ease; }
header.nav.scrolled .nav-mark{ opacity:1; visibility:visible; pointer-events:auto; }
.nav-wordmark{
  font-family:var(--f-display); text-transform:uppercase; font-weight:700;
  letter-spacing:.02em; font-size:1.4rem; color:var(--brand); line-height:1;
}
.hero p.sub{ font-size:1.18rem; max-width:44ch; opacity:.95; margin:0 0 14px; line-height:1.55; }
.hero-blurb{ font-size:1.02rem; max-width:50ch; opacity:.9; margin:0 0 30px; line-height:1.6; }
.hero-actions{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.hero-rating{ display:flex; flex-direction:column; align-items:flex-start; gap:7px; margin-top:24px; max-width:52ch; }
.hero-rating .stars{ color:#ffd23f; letter-spacing:3px; font-size:1.2rem; line-height:1; text-shadow:0 1px 4px rgba(120,40,50,.3); }
.maker-credit{ font-size:.82rem; line-height:1.55; opacity:.92; }

/* phone — iPhone 17 Pro */
.phone{
  position:relative; width:300px; margin:0 auto;
  background:linear-gradient(145deg,#3a3a3d,#1c1c1e 40%,#2c2c2e); border-radius:48px; padding:7px;
  box-shadow:0 40px 80px rgba(120,40,55,.4), inset 0 0 0 1.5px rgba(255,255,255,.14), 0 0 0 1.5px rgba(0,0,0,.5);
}
.phone-screen{
  position:relative; width:100%; aspect-ratio:296/640; border-radius:42px; overflow:hidden;
  background:#000;
}
.phone-screen video, .phone-screen img{ width:100%; height:100%; object-fit:cover; display:block; }

.hero-phone-wrap{ position:relative; }
.float-sticker{ position:absolute; width:120px; opacity:.96; filter:drop-shadow(0 10px 20px rgba(120,40,50,.25)); pointer-events:none; }

/* blob decor */
.hero-blob{ position:absolute; border-radius:50%; filter:blur(8px); opacity:.5; pointer-events:none; }

/* ---------- section base ---------- */
section{ position:relative; }
.section{ padding:96px 0; }
.section.peach{ background:var(--peach); }
.section.cream{ background:var(--cream); }
.section.white{ background:#fff; }
.sec-head{ text-align:center; max-width:680px; margin:0 auto 56px; }
.sec-head .eyebrow-script{ color:var(--brand); display:block; margin-bottom:6px; }
.sec-head p{ color:var(--ink-soft); font-size:1.1rem; margin:14px auto 0; max-width:54ch; }

/* ---------- trust bar ---------- */
.trust{ background:var(--hero-grad); padding:64px 0; color:#fff; }
.trust-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.trust-card{
  background:#fff; border-radius:24px; padding:30px 22px; text-align:center;
  box-shadow:var(--sh-card);
}
.trust-card .big{
  font-family:var(--f-display); font-weight:700; text-transform:uppercase;
  color:var(--brand); font-size:2.5rem; line-height:1; letter-spacing:.01em;
}
.trust-card .lbl{
  font-family:var(--f-display); text-transform:uppercase; letter-spacing:.14em;
  font-size:.74rem; font-weight:600; color:var(--ink); margin-top:8px;
}
.trust-card .sub{ font-size:.86rem; color:var(--ink-soft); margin-top:7px; line-height:1.4; }
.trust-stars{ color:#ffc62b; font-size:1.6rem; line-height:1; letter-spacing:2px; }

/* ---------- feature rows ---------- */
.feature{ display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:center; position:relative; }
.tab-row{ border-bottom:3px solid var(--brand); margin-bottom:18px; line-height:0; }
.section-tab{
  display:inline-block; position:relative; bottom:-3px;
  background:var(--brand); color:#fff;
  font-family:var(--f-display); text-transform:uppercase; font-weight:700;
  letter-spacing:.14em; font-size:.95rem; line-height:1;
  padding:12px 24px 14px; border-radius:16px 16px 0 0;
}
.feature + .feature{ margin-top:110px; }
.feature.reverse .feat-media{ order:2; }
.feat-copy .kicker{ display:block; margin-bottom:14px; }
.feat-copy h2{ margin-bottom:18px; }
.feat-copy p{ color:var(--ink-soft); font-size:1.1rem; }
.feat-list{ list-style:none; padding:0; margin:24px 0 0; display:grid; gap:13px; }
.feat-list li{ display:flex; gap:12px; align-items:flex-start; font-size:1.02rem; color:var(--ink); }
.feat-list .tick{
  flex:none; width:24px; height:24px; border-radius:50%; background:var(--brand);
  color:#fff; display:grid; place-items:center; font-size:.7rem; margin-top:3px;
}
.feat-media{ position:relative; }

/* background swap grid */
.bgswap{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; align-items:start; }
.bgswap img{ width:100%; height:auto; object-fit:contain; filter:drop-shadow(0 10px 18px rgba(120,55,60,.32)); }
.bgswap{ position:relative; margin-top:48px; }
.bgswap .pill{
  position:absolute; top:-44px; left:50%; transform:translateX(-50%);
  background:#fff; color:var(--brand); font-family:var(--f-script); font-size:1.4rem;
  padding:2px 22px; border-radius:999px; box-shadow:var(--sh-sm); white-space:nowrap;
}

/* ---------- make it yours (tools) ---------- */
.tools-row{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1060px; margin:30px auto 0; }
.tools-row-2{ grid-template-columns:repeat(2,1fr); max-width:720px; }

/* stickers feature (lead) */
.stickers-feature{
  display:grid; grid-template-columns:.82fr 1.18fr; gap:40px; align-items:center;
  max-width:1060px; margin:0 auto 34px;
}
.stickers-copy .kicker{ display:block; }
.stickers-copy p{ color:var(--ink-soft); font-size:1.02rem; margin:0; line-height:1.6; }
.stickers-copy strong{ color:var(--ink); font-weight:600; }
.sticker-tags{ display:flex; gap:9px; flex-wrap:wrap; margin-top:20px; }
.sticker-tag{
  font-family:var(--f-display); text-transform:uppercase; letter-spacing:.08em; font-size:.74rem; font-weight:600;
  color:var(--brand); background:#fff; border:1.5px solid var(--brand-soft);
  padding:.5em 1.1em; border-radius:999px;
}
.sticker-phones{ display:flex; justify-content:center; align-items:center; gap:13px; }
.sticker-phones .phone{ width:100%; max-width:158px; border-radius:30px; padding:5px; }
.sticker-phones .phone-screen{ border-radius:26px; }
.sticker-phones .phone:nth-child(odd){ transform:translateY(16px) scale(.95); }
.sticker-phones .phone:nth-child(even){ z-index:2; }

/* fonts feature */
.fonts-feature{
  display:grid; grid-template-columns:1fr 1fr; gap:34px; align-items:center;
  max-width:1060px; margin:34px auto 0; background:#fff; border-radius:28px;
  padding:30px; box-shadow:var(--sh-md);
}
.fonts-feature .tool-fonts{
  display:flex; flex-direction:column; gap:11px; align-items:flex-start;
  background:linear-gradient(160deg,#fff8f2,var(--peach)); border-radius:20px; padding:30px;
}
.fonts-feature .tool-fonts span{ color:var(--ink); line-height:1; font-size:1.5rem; opacity:.78; }
.fonts-feature .tool-fonts .font-selected{ color:var(--brand); opacity:1; font-size:2.1rem; }
.fonts-copy .kicker{ display:block; }
.fonts-copy p{ color:var(--ink-soft); font-size:1.02rem; margin:0; line-height:1.6; }
.fonts-copy strong{ color:var(--ink); font-weight:600; }


/* featured background swapper */
.bg-feature{
  display:grid; grid-template-columns:1fr 1fr; gap:34px; align-items:center;
  max-width:1060px; margin:0 auto; background:#fff; border-radius:28px;
  padding:26px; box-shadow:var(--sh-md);
}
.bg-stage{ position:relative; border-radius:20px; overflow:hidden; box-shadow:var(--sh-md); background:var(--peach); }
.bg-stage img{ width:100%; aspect-ratio:1; object-fit:cover; display:block; transition:opacity .4s ease; }
.bg-stage.swapping img{ opacity:0; }
.bg-badge{
  position:absolute; left:14px; bottom:14px; display:inline-flex; align-items:center; gap:.55em;
  background:rgba(255,255,255,.94); color:var(--ink); border-radius:999px;
  padding:.5em 1em .5em .5em; font-size:.84rem; font-weight:600; box-shadow:var(--sh-sm);
}
.bg-badge-k{
  font-family:var(--f-display); text-transform:uppercase; letter-spacing:.08em; font-size:.6rem;
  background:var(--brand); color:#fff; padding:.5em .8em; border-radius:999px;
}
.bg-control .kicker{ display:block; }
.bg-control p{ color:var(--ink-soft); font-size:1rem; margin:0 0 18px; line-height:1.55; }
.scene-thumbs{ display:grid; grid-template-columns:repeat(6,1fr); gap:10px; }
.scene-thumb{
  padding:0; border:2.5px solid transparent; border-radius:13px; overflow:hidden; cursor:pointer;
  background:none; aspect-ratio:1; transition:border-color .2s ease, transform .2s ease; line-height:0;
}
.scene-thumb img{ width:100%; height:100%; object-fit:cover; }
.scene-thumb:hover{ transform:translateY(-3px); }
.scene-thumb.is-active{ border-color:var(--brand); }

.tool-card{
  background:#fff; border-radius:24px; overflow:hidden; box-shadow:var(--sh-md);
  display:flex; flex-direction:column; transition:transform .28s ease, box-shadow .28s ease;
}
.tool-card:hover{ transform:translateY(-6px); box-shadow:var(--sh-lg); }
.tool-visual{
  position:relative; height:210px; display:grid; place-items:center; padding:22px; overflow:hidden;
}
.tool-visual img{ max-width:100%; max-height:100%; width:auto; height:auto; object-fit:contain; }
.tint-blue{ background:linear-gradient(160deg,#f3f6fb,#e8eef6); }
.tint-cream{ background:linear-gradient(160deg,#fff8f2,var(--peach)); }
.tint-white{ background:#fff; box-shadow:inset 0 0 0 1px var(--hairline); }
.tool-fonts{ flex-direction:column; gap:9px; padding:24px; }
.tool-fonts span{ color:var(--ink); line-height:1; font-size:1.35rem; opacity:.78; }
.tool-fonts .font-selected{
  color:var(--brand); opacity:1; font-size:2rem; position:relative;
}
.tool-chip{
  position:absolute; bottom:14px; right:14px;
  font-family:var(--f-display); text-transform:uppercase; letter-spacing:.1em; font-size:.66rem; font-weight:600;
  background:rgba(255,255,255,.92); color:var(--brand); padding:.45em 1em; border-radius:999px; box-shadow:var(--sh-sm);
}
.tool-body{ padding:24px 26px 28px; }
.tool-body h3{
  font-family:var(--f-display); text-transform:uppercase; letter-spacing:.03em;
  font-size:1.35rem; color:#1a1416; margin:0 0 8px;
}
.tool-body p{ color:var(--ink-soft); font-size:1rem; margin:0; line-height:1.55; }
.tool-body strong{ color:var(--ink); font-weight:600; }

/* ---------- carousel (collages) ---------- */
.carousel{ position:relative; }
.carousel-stage{
  position:relative; width:100%; aspect-ratio:4/5; border-radius:0; overflow:visible;
  background:transparent;
  box-shadow:none; display:grid; place-items:center;
}
.carousel-img{
  position:absolute; inset:0; margin:auto; max-width:86%; max-height:86%;
  width:auto; height:auto; object-fit:contain; border-radius:14px;
  box-shadow:0 16px 40px rgba(120,55,60,.24);
  opacity:0; transform:scale(.98); transition:opacity .45s ease, transform .45s ease; pointer-events:none;
}
.carousel-img.is-active{ opacity:1; transform:scale(1); pointer-events:auto; }
.carousel-arrow{
  position:absolute; top:50%; transform:translateY(-50%); z-index:3;
  width:46px; height:46px; border-radius:50%; border:none; cursor:pointer;
  background:rgba(255,255,255,.9); color:var(--brand); font-size:1.9rem; line-height:1;
  display:grid; place-items:center; box-shadow:var(--sh-md); transition:transform .18s ease, background .18s ease;
}
.carousel-arrow:hover{ background:#fff; transform:translateY(-50%) scale(1.08); }
.carousel-arrow.prev{ left:-12px; padding-right:3px; }
.carousel-arrow.next{ right:-12px; padding-left:3px; }
.carousel-dots{ display:flex; justify-content:center; gap:8px; margin-top:18px; flex-wrap:wrap; }
/* beyond carousel: squarer stage; shadow follows each photo's real shape (no corner slivers) */
#beyondCarousel .carousel-stage{ aspect-ratio:1/1; }
#beyondCarousel .carousel-img{ max-width:94%; max-height:94%; border-radius:0; box-shadow:none; filter:none; }
#beyondCarousel .carousel-img.is-active{ filter:none; }
#beyondCarousel .carousel-dots{ margin-top:4px; }
.carousel-dots button{
  width:9px; height:9px; padding:0; border:none; border-radius:50%; cursor:pointer;
  background:var(--brand-soft); opacity:.55; transition:.22s;
}
.carousel-dots button.active{ opacity:1; background:var(--brand); transform:scale(1.25); }

/* slideshow quad */
.slide-quad{ display:grid; grid-template-columns:repeat(2,1fr); gap:22px 20px; justify-items:center; max-width:480px; margin:0 auto; }
.slide-quad .phone{ width:100%; max-width:208px; }
.slide-quad .phone:nth-child(odd){ transform:translateY(-14px); }
.slide-quad .phone:nth-child(even){ transform:translateY(14px); }

/* sticker band */
.sticker-band{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.sticker-band img{ border-radius:22px; background:#fff; box-shadow:var(--sh-md); padding:18px; }

/* ---------- gallery (flex-column masonry — no multicol clipping) ---------- */
.gallery{ display:flex; gap:22px; align-items:flex-start; }
.gallery-col{ flex:1 1 0; display:flex; flex-direction:column; gap:22px; min-width:0; }
.gallery .g-item{ position:relative; }
.gallery .g-item img{ width:100%; height:auto; display:block; border-radius:0; box-shadow:none; filter:none; }
.gallery-feature{ display:flex; justify-content:flex-end; margin-top:18px; }
.gallery-banner{ margin-top:22px; display:flex; justify-content:center; }
.gallery-banner img{ width:50%; height:auto; display:block; border-radius:6px; }
@media (max-width:760px){ .gallery-banner img{ width:100%; } }
.gallery-feature .g-item{
  width:min(50%, 520px); position:relative;
}
.gallery-feature .g-item img{ width:100%; height:auto; display:block; border-radius:16px; box-shadow:var(--sh-md); }
@media (max-width:760px){ .gallery-feature .g-item{ width:100%; } }

/* tag chips */
.chips{ display:flex; justify-content:center; gap:10px; flex-wrap:wrap; margin:34px 0 0; }
.chip{
  font-family:var(--f-display); text-transform:uppercase; letter-spacing:.1em;
  font-size:.78rem; font-weight:500; padding:.6em 1.3em; border-radius:999px;
  background:#fff; color:var(--ink-soft); box-shadow:var(--sh-sm); cursor:pointer;
  border:1.5px solid transparent; transition:.2s;
}
.chip.active, .chip:hover{ color:var(--brand); border-color:var(--brand-soft); }

/* ---------- beyond the bump ---------- */
.beyond{ display:grid; grid-template-columns:1.1fr .9fr; gap:60px; align-items:start; }
.milestones{ display:grid; gap:14px; }
.ms{
  display:flex; align-items:center; gap:18px; background:#fff; border-radius:18px;
  padding:18px 22px; box-shadow:var(--sh-sm);
}
.ms .ms-ico{ flex:none; width:52px; height:52px; border-radius:14px; background:var(--peach); display:grid; place-items:center; font-size:1.4rem; }
.ms .ms-ico.has-img{ background:transparent; }
.ms .ms-ico.has-img img{ width:100%; height:100%; object-fit:contain; display:block; }
.ms .ms-t{ font-family:var(--f-display); text-transform:uppercase; letter-spacing:.06em; font-weight:600; font-size:1rem; }
.ms .ms-d{ font-size:.92rem; color:var(--ink-soft); }
.beyond-media{ width:100%; }

/* ---------- pricing (comparison) ---------- */
.compare{
  max-width:760px; margin:0 auto;
  background:#fff; border-radius:var(--radius); box-shadow:var(--sh-lg);
  padding:14px 30px 26px; overflow:hidden;
}
.cmp-row{
  display:grid; grid-template-columns:1fr 132px 132px; align-items:center;
  padding:15px 0; border-bottom:1px solid var(--hairline);
}
.cmp-row:last-child{ border-bottom:none; }
.cmp-feature{ font-size:1rem; color:var(--ink); padding-right:14px; }
.cmp-col{ text-align:center; font-size:.9rem; color:var(--ink-soft); }
.cmp-head{ border-bottom:2px solid var(--hairline); }
.cmp-head .cmp-col{
  font-family:var(--f-display); text-transform:uppercase; letter-spacing:.08em;
  font-size:1.05rem; font-weight:600; color:var(--ink);
}
.cmp-head .cmp-pro{ color:var(--brand); }
.cmp-col .yes{ color:var(--brand); font-weight:600; }
.cmp-col .some{ color:var(--ink-soft); }
.cmp-col .no{ color:var(--ink-faint); }
.cmp-foot .cmp-col{ display:flex; flex-direction:column; gap:2px; padding-top:4px; }
.cmp-price{ font-family:var(--f-display); font-weight:700; text-transform:uppercase; font-size:1.5rem; color:var(--brand); line-height:1; }
.cmp-sub{ font-size:.78rem; color:var(--ink-soft); }
.price-list{ list-style:none; padding:0; margin:0 0 28px; display:grid; gap:12px; }
.price-list li{ display:flex; gap:11px; align-items:flex-start; font-size:.98rem; }
.price-list .tick{ flex:none; width:21px; height:21px; border-radius:50%; background:var(--brand); color:#fff; display:grid; place-items:center; font-size:.62rem; margin-top:3px; }
.pricing-cta{ text-align:center; margin-top:38px; display:flex; flex-direction:column; align-items:center; gap:14px; }
.pricing-note{ font-size:.95rem; color:var(--ink-soft); margin:0; }

/* ---------- privacy ---------- */
.privacy{
  background:var(--hero-grad); color:#fff; border-radius:var(--radius);
  padding:60px; text-align:center; max-width:880px; margin:0 auto;
  box-shadow:var(--sh-lg);
}
.privacy .lock{ font-size:2.4rem; margin-bottom:10px; }
.privacy h2{ color:#fff; margin-bottom:16px; }
.privacy p{ max-width:54ch; margin:0 auto; opacity:.96; font-size:1.1rem; }

/* ---------- final CTA ---------- */
.cta-final{ text-align:center; padding:110px 0; background:var(--peach); }
.cta-final .eyebrow-script{ color:var(--brand); font-size:2.3rem; }
.cta-final h2{ margin:8px auto 18px; max-width:18ch; }
.cta-final p{ color:var(--ink-soft); max-width:46ch; margin:0 auto 32px; font-size:1.1rem; }

/* ---------- footer ---------- */
footer{ background:#2c2326; color:rgba(255,255,255,.78); padding:64px 0 34px; }
.foot-top{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; align-items:flex-start; }
footer .logo{ color:#fff; font-size:1.8rem; font-family:var(--f-display); font-weight:700; text-transform:uppercase; letter-spacing:.02em; }
footer .f-tag{ font-family:var(--f-script); font-size:1.5rem; color:var(--brand-soft); margin-top:4px; }
.foot-cols{ display:flex; gap:64px; flex-wrap:wrap; }
.foot-col h4{ font-family:var(--f-display); text-transform:uppercase; letter-spacing:.12em; font-size:.78rem; color:#fff; margin:0 0 14px; }
.foot-col a{ display:block; font-size:.92rem; margin-bottom:9px; opacity:.78; transition:.2s; }
.foot-col a:hover{ opacity:1; color:var(--brand-soft); }
.foot-bottom{ margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.12); display:flex; justify-content:space-between; gap:18px; flex-wrap:wrap; font-size:.84rem; opacity:.66; }

/* ---------- lightbox ---------- */
.lightbox{
  position:fixed; inset:0; z-index:200; background:rgba(40,24,28,.86);
  display:none; align-items:center; justify-content:center; padding:30px;
  backdrop-filter:blur(6px); opacity:0; transition:opacity .25s ease;
}
.lightbox.open{ display:flex; opacity:1; }
.lightbox img{ max-width:min(92vw,640px); max-height:88vh; border-radius:18px; box-shadow:0 30px 80px rgba(0,0,0,.5); }
.lightbox .lb-close{ position:absolute; top:22px; right:26px; width:46px; height:46px; border-radius:50%; background:rgba(255,255,255,.16); color:#fff; border:none; font-size:1.4rem; cursor:pointer; }
.lightbox .lb-close:hover{ background:rgba(255,255,255,.28); }

/* ---------- reveal anim ---------- */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-inner{ grid-template-columns:1fr; text-align:center; gap:30px; }
  .hero-copy .lead, .hero p.sub{ margin-left:auto; margin-right:auto; }
  .hero-actions, .hero-rating{ justify-content:center; }
  .hero-phone-wrap{ order:-1; }
  .feature{ grid-template-columns:1fr; gap:34px; }
  .feature.reverse .feat-media{ order:0; }
  .feat-copy{ text-align:center; }
  .feat-copy .kicker, .sec-head .eyebrow-script{ }
  .feat-list{ max-width:440px; margin-left:auto; margin-right:auto; text-align:left; }
  .beyond{ grid-template-columns:1fr; gap:36px; }
  .beyond-media{ margin-top:0; }
  .trust-grid{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:760px){
  .nav-links{
    position:fixed; top:0; right:0; height:100vh; width:min(78vw,320px);
    background:#fff; flex-direction:column; align-items:flex-start; justify-content:center;
    padding:40px; gap:26px; transform:translateX(100%); transition:transform .34s ease;
    box-shadow:-10px 0 40px rgba(120,60,60,.18); z-index:70;
  }
  .nav-links.open{ transform:translateX(0); }
  .nav-links a{ color:var(--ink) !important; font-size:1.05rem; }
  .nav-toggle{ display:block; z-index:80; }
  .compare{ padding:10px 16px 20px; }
  .cmp-row{ grid-template-columns:1fr 74px 74px; }
  .cmp-feature{ font-size:.9rem; }
  .cmp-col{ font-size:.8rem; }
  .tools-grid{ grid-template-columns:1fr; max-width:460px; }
  .tools-row{ grid-template-columns:1fr; max-width:420px; }
  .fonts-feature{ grid-template-columns:1fr; max-width:460px; gap:22px; padding:20px; text-align:center; }
  .fonts-feature .tool-fonts{ align-items:center; }
  .fonts-feature .fonts-copy .kicker{ display:block; }
  .stickers-feature{ grid-template-columns:1fr; max-width:480px; gap:26px; text-align:center; }
  .stickers-copy .sticker-tags{ justify-content:center; }
  .sticker-phones{ gap:10px; flex-wrap:wrap; }
  .sticker-phones .phone{ max-width:128px; }
  .bg-feature{ grid-template-columns:1fr; max-width:460px; gap:22px; padding:18px; }
  .scene-thumbs{ grid-template-columns:repeat(6,1fr); }
  .sticker-band{ grid-template-columns:1fr; }
  .slide-quad{ max-width:420px; }
  .slide-quad .phone:nth-child(odd),
  .slide-quad .phone:nth-child(even){ transform:none; }
  .bgswap{ grid-template-columns:repeat(2,1fr); }
  .privacy{ padding:40px 26px; }
  .section{ padding:70px 0; }
  body{ font-size:17px; }
}
@media (max-width:440px){
  .trust-grid{ grid-template-columns:1fr; }
  .wrap{ padding:0 18px; }
  .gallery{ gap:12px; }
  .gallery-col{ gap:12px; }
}
