:root{
  --purple:#7b2d8e; --purple-d:#4a1d6e; --magenta:#d6168f;
  --cream:#f8f1dd; --cream-2:#f3ead0; --ink:#2c2230; --muted:#7a7280;
  --card:#ffffff; --line:#e7ddc7;
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0}
body{background:var(--cream);color:var(--ink);
  font:16px/1.55 ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;}
img{max-width:100%;display:block}
h1{font-size:1.7rem;line-height:1.15;text-align:center;color:var(--purple-d);letter-spacing:-.02em;margin:.2rem 0 .6rem}
h2{font-size:1.25rem;text-align:center;color:var(--purple-d);margin:1.4rem 0 .8rem}
.sub{text-align:center;color:var(--muted);margin:0 auto 1.4rem;max-width:30rem}
.center{text-align:center}.muted{color:var(--muted)}
.grad{background:linear-gradient(90deg,var(--purple),var(--magenta));-webkit-background-clip:text;background-clip:text;color:transparent}

.topbar{display:flex;align-items:center;justify-content:space-between;gap:.5rem;
  padding:.7rem 1rem;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:10}
.brand{display:flex;align-items:center;gap:.35rem;font-weight:800;color:var(--purple-d);font-size:1.15rem;cursor:pointer}
.brand-mark{color:var(--magenta)}
.rating{font-size:.72rem;color:#1c8a5a}.rating b{color:var(--ink)}

#app{margin:0 auto}
.step{display:none;animation:fade .25s ease}
.step.active{display:block}
.step:not(.full){max-width:30rem;margin:0 auto;padding:1.25rem 1.1rem 3rem}
.step.full{width:100%}
@keyframes fade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}

.cta{display:block;width:100%;margin:1.2rem 0 0;padding:1rem;border:0;border-radius:999px;cursor:pointer;
  background:linear-gradient(90deg,var(--purple),#5b2475);color:#fff;font-size:1.05rem;font-weight:700;
  box-shadow:0 6px 18px rgba(91,36,117,.35);transition:transform .08s}
.cta:active{transform:translateY(1px)}
.cta:disabled{opacity:.45;box-shadow:none;cursor:default}
.btn-sm{margin-top:.7rem;padding:.5rem 1.2rem;border:0;border-radius:999px;background:var(--magenta);color:#fff;font-weight:700;cursor:pointer}
.link{background:none;border:0;color:var(--purple);text-decoration:underline;cursor:pointer;font-size:.9rem}
.lock{text-align:center;font-size:.78rem;color:var(--muted);margin:.8rem 0 0}

/* ===== landing (full-width marketing) ===== */
.wrap{max-width:64rem;margin:0 auto;padding:0 1.25rem}
.wrap.narrow{max-width:44rem}
.promo{background:linear-gradient(90deg,var(--magenta),var(--purple));color:#fff;text-align:center;font-size:.82rem;font-weight:700;padding:.55rem 1rem}
.hero{background:radial-gradient(120% 90% at 50% 0,#fff,var(--cream) 70%);padding:2.4rem 0 2.8rem}
.hero-grid{display:grid;gap:1.8rem;align-items:center}
.hero-copy{text-align:center}
.hero-copy h1{text-align:center;font-size:2rem}
.trust{text-align:center;font-size:.82rem;color:var(--muted);margin:.8rem 0 0}
.ba-real{display:flex;align-items:center;gap:.5rem;max-width:30rem;margin:0 auto;width:100%}
.ba-real figure{flex:1;margin:0;position:relative}
.ba-real img{aspect-ratio:1;object-fit:cover;border-radius:16px;width:100%;box-shadow:0 8px 24px rgba(74,29,110,.15)}
.ba-arrow{color:var(--magenta);font-size:1.4rem;font-weight:900;flex:none}
.tag{position:absolute;top:.5rem;left:.5rem;z-index:1;font-size:.6rem;font-weight:800;padding:.2rem .5rem;border-radius:999px;background:#fff;color:var(--purple-d)}
.tag.after{background:var(--magenta);color:#fff}
.seenon{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1rem;text-align:center}
.seenon span{display:block;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:.3rem}
.badges{color:var(--purple-d);font-size:.95rem}.badges b{color:var(--magenta)}
.full .band{padding:2.8rem 0;background:var(--cream-2)}
.full .band.alt{background:#fff;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.full .cta{max-width:24rem;margin:1.4rem auto 0}
.steps3{display:grid;gap:1.1rem;margin:1.4rem 0}
.steps3>div{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:1rem;text-align:left}
.steps3 img{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:12px;margin-bottom:.7rem}
.steps3 .num{position:absolute;top:1.4rem;left:1.4rem;width:1.8rem;height:1.8rem;border-radius:999px;background:var(--purple);color:#fff;display:grid;place-items:center;font-weight:800;font-size:.85rem}
.steps3 b{color:var(--purple-d)}.steps3 p{margin:.2rem 0 0;color:var(--muted);font-size:.9rem}
.theme-grid-wide{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.7rem;margin:1.2rem 0}
.real-grid{display:grid;gap:1.6rem;align-items:center}
.real-copy h2{text-align:left}
.real-copy p{color:var(--muted)}
.checks{list-style:none;padding:0;margin:1rem 0 0}
.checks li{margin:.6rem 0}
.checks b{display:block;color:var(--purple-d)}
.checks span{color:var(--muted);font-size:.9rem}
.testi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.9rem;margin:1.4rem 0}
.testi{margin:0;background:#fff;border:1px solid var(--line);border-radius:16px;padding:.9rem}
.thead{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}
.thead .av{flex:none;width:2.1rem;height:2.1rem;border-radius:999px;background:var(--purple);color:#fff;display:grid;place-items:center;font-weight:700;font-size:.72rem}
.thead b{display:block;font-size:.85rem;color:var(--purple-d)}
.thead span{font-size:.68rem;color:var(--muted)}
.thead .st{margin-left:auto;color:#f5b301;font-size:.8rem}
.testi p{font-style:italic;font-size:.86rem;margin:.2rem 0 .7rem}
.testi img{width:100%;aspect-ratio:1;object-fit:cover;border-radius:12px}
.feat4{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-top:1.4rem;text-align:center}
.feat4 .ico{font-size:1.8rem}
.feat4 b{display:block;color:var(--purple-d);margin:.3rem 0 .15rem}
.feat4 p{color:var(--muted);font-size:.85rem;margin:0}
.giftbox{background:linear-gradient(135deg,var(--purple),#5b2475);color:#fff;border-radius:20px;padding:1.8rem;text-align:center}
.giftbox h3{margin:0 0 .5rem;font-size:1.3rem}
.giftbox p{color:#e9d8f1;margin:0}
.giftbox .cta{background:#fff;color:var(--purple-d)}
.faq{margin:1.2rem 0}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:.2rem .9rem;margin-bottom:.6rem}
.faq summary{cursor:pointer;font-weight:700;color:var(--purple-d);padding:.7rem 0;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--magenta);font-weight:900}
.faq details[open] summary::after{content:"\2013"}
.faq p{margin:0 0 .8rem;color:var(--muted);font-size:.9rem}
@media(min-width:760px){
  .hero-grid{grid-template-columns:1.05fr .95fr}
  .hero-copy,.hero-copy h1{text-align:left}
  .hero-copy h1{font-size:2.7rem}
  .full .hero-copy .cta{margin:1.4rem 0 0}
  .steps3{grid-template-columns:repeat(3,1fr)}
  .real-grid{grid-template-columns:1fr 1fr}
}

/* upload */
.dropzone{margin-top:.5rem;border:2px dashed #cdbce0;border-radius:18px;background:#fdfaff;padding:1.6rem 1rem;text-align:center}
.dz-cloud{font-size:1.6rem;color:var(--purple)}
.dz-idle b{display:block;margin:.4rem 0 .15rem;color:var(--ink)}
.dz-idle small{color:var(--muted);font-size:.8rem}
.dropzone.drag{background:#f3e9fb;border-color:var(--purple)}
.dz-have img{max-height:240px;margin:0 auto;border-radius:12px}
.dz-have .link{margin-top:.6rem}

/* theme grid */
.theme-grid{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.tile{position:relative;aspect-ratio:1;border-radius:16px;overflow:hidden;cursor:pointer;border:3px solid transparent;
  background:linear-gradient(135deg,#caa9e0,#e9b8d6)}
.tile img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.tile .name{position:absolute;left:.4rem;bottom:.4rem;right:.4rem;font-size:.78rem;font-weight:700;color:#fff;
  background:rgba(40,20,50,.55);padding:.25rem .5rem;border-radius:999px;backdrop-filter:blur(2px)}
.tile.sel{border-color:var(--purple);box-shadow:0 0 0 3px rgba(123,45,142,.25)}
.tile.sel::after{content:"✓";position:absolute;top:.4rem;right:.5rem;width:1.4rem;height:1.4rem;border-radius:999px;background:var(--purple);color:#fff;display:grid;place-items:center;font-size:.8rem;font-weight:800}
.more{text-align:center;color:var(--muted);font-size:.85rem;margin-top:1rem}.more b{color:var(--magenta)}

/* generating */
.review{display:flex;gap:.7rem;background:#fff;border:1px solid var(--line);border-radius:14px;padding:.8rem;margin:.4rem 0 1.4rem}
.avatar{flex:none;width:2.4rem;height:2.4rem;border-radius:999px;background:#4a90d9;color:#fff;display:grid;place-items:center;font-weight:700;font-size:.8rem}
.vc{font-size:.72rem;color:var(--muted);margin-left:.4rem}.stars{color:#f5b301;margin-left:.4rem;font-size:.8rem}
.review p{margin:.3rem 0 0;font-style:italic;font-size:.9rem}
.progress-wrap{position:relative;width:130px;margin:1rem auto}
.ring{transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:#e7ddc7;stroke-width:10}
.ring-fg{fill:none;stroke:var(--purple);stroke-width:10;stroke-linecap:round;stroke-dasharray:327;stroke-dashoffset:327;transition:stroke-dashoffset .4s}
.pct{position:absolute;inset:0;display:grid;place-items:center;font-weight:800;color:var(--purple-d)}

/* preview / email / paywall */
.preview{width:100%;border-radius:18px;margin:.4rem 0 1rem;aspect-ratio:1;object-fit:cover;background:#eadff5}
.preview.blurred{filter:blur(18px) saturate(1.1);transform:scale(1.02)}
.wm-wrap{position:relative;margin:.4rem 0 1rem}
.wm-wrap .preview{margin:0}
.wm-badge{position:absolute;left:50%;bottom:.7rem;transform:translateX(-50%);white-space:nowrap;max-width:92%;
  background:rgba(40,20,50,.82);color:#fff;font-size:.74rem;font-weight:700;padding:.4rem .85rem;border-radius:999px}
.benefits{list-style:none;padding:0;max-width:18rem;margin:.4rem auto 1rem;color:var(--ink)}
.benefits li{padding:.15rem 0}
#emailForm input,#emailInput{width:100%;padding:.9rem 1rem;border:1px solid var(--line);border-radius:12px;font-size:1rem;background:#fff}
.getlist{background:var(--cream-2);border-radius:16px;padding:1rem 1.1rem;margin:.4rem 0}
.getlist ul{margin:.5rem 0 0;padding-left:1.1rem}.getlist li{margin:.2rem 0;font-size:.92rem}

/* post-payment style choice */
.style-choice{margin:1rem auto 0;max-width:540px}
.sc-h{font-weight:700;text-align:center;margin:0 0 .55rem}
.sc-opts{display:flex;gap:.6rem}
.sc-opt{flex:1;border:2px solid var(--cream-2,#eee);background:#fff;border-radius:14px;padding:.7rem .55rem;cursor:pointer;text-align:center;transition:.15s;font:inherit}
.sc-opt b{display:block;font-size:.95rem;color:#3a2b40}
.sc-opt small{color:#9a8aa0;font-size:.76rem}
.sc-opt.on{border-color:#a855f7;background:#faf5ff;box-shadow:0 4px 14px rgba(168,85,247,.18)}
.sc-note{text-align:center;color:#9a8aa0;font-size:.78rem;margin:.55rem 0 0}

/* packages */
.packages{display:grid;gap:.7rem}
.pkg{position:relative;display:flex;align-items:center;justify-content:space-between;gap:.6rem;
  border:2px solid var(--line);border-radius:16px;background:#fff;padding:1rem;cursor:pointer}
.pkg.sel{border-color:var(--purple);box-shadow:0 0 0 3px rgba(123,45,142,.18)}
.pkg.pop{border-color:var(--magenta)}
.pkg .pname{font-weight:800;color:var(--purple-d)}
.pkg .pblurb{font-size:.8rem;color:var(--muted)}
.pkg .pprice{font-weight:800;font-size:1.2rem}
.pkg .pper{font-size:.7rem;color:var(--muted);text-align:right}
.badge{position:absolute;top:-.6rem;left:1rem;background:var(--magenta);color:#fff;font-size:.66rem;font-weight:800;padding:.15rem .6rem;border-radius:999px}

/* reveal */
.progress-line{height:8px;background:#e7ddc7;border-radius:999px;overflow:hidden;margin:.4rem 0 1.2rem}
#revealBar{height:100%;width:0;background:linear-gradient(90deg,var(--purple),var(--magenta));transition:width .5s}
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
.gallery a{display:block;border-radius:14px;overflow:hidden;border:1px solid var(--line)}
.gallery img{aspect-ratio:1;object-fit:cover;width:100%;display:block}
.magic{text-align:center;background:var(--cream-2);border:1px solid var(--line);border-radius:14px;padding:.9rem;margin:.6rem 0 1rem;font-weight:600;color:var(--purple-d);min-height:1.2em}
.revealcount{color:var(--muted);font-size:.85rem;margin:.4rem 0 1rem}
.gtile{aspect-ratio:1;border-radius:14px;overflow:hidden;border:1px solid var(--line);background:#eadff5}
.gtile a,.gtile img{display:block;width:100%;height:100%;object-fit:cover}
.skel{background:linear-gradient(100deg,#efe6f5 30%,#f8f1fb 50%,#efe6f5 70%);background-size:200% 100%;animation:shimmer 1.4s infinite}
@keyframes shimmer{from{background-position:200% 0}to{background-position:-200% 0}}
.reveal-done{text-align:center;margin-top:1.2rem}
.reveal-done p{color:var(--ink)}

.foot{text-align:center;font-size:.78rem;color:var(--muted);padding:1.4rem;border-top:1px solid var(--line)}
.foot a{color:var(--muted)}
