:root{
  --plum:#2a0f33;
  --plum-2:#43164f;
  --rose:#ff5c8a;
  --rose-deep:#e23b6d;
  --cream:#fff5f8;
  --gold:#ffd479;
  --ink:#3a1430;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:"Segoe UI",-apple-system,system-ui,sans-serif;
  background:radial-gradient(circle at 30% 20%,var(--plum-2),var(--plum) 70%);
  color:var(--cream);
  min-height:100vh;min-height:100dvh;
  overflow-x:hidden;position:relative;
  display:flex;align-items:center;justify-content:center;
  padding:max(28px,env(safe-area-inset-top)) 16px max(28px,env(safe-area-inset-bottom));
}

/* ambient floating hearts */
#hearts{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.heart{
  position:absolute;bottom:-40px;opacity:0;will-change:transform,opacity;
  animation:rise linear infinite;
}
@keyframes rise{
  0%{transform:translateY(0) rotate(0);opacity:0}
  10%{opacity:.5}90%{opacity:.5}
  100%{transform:translateY(-115vh) rotate(40deg);opacity:0}
}

/* burst hearts on tap */
#burst{position:fixed;inset:0;z-index:5;overflow:hidden;pointer-events:none}
.pop{position:absolute;will-change:transform,opacity;animation:pop .9s ease-out forwards}
@keyframes pop{
  0%{transform:translate(0,0) scale(.4);opacity:1}
  100%{transform:translate(var(--dx),var(--dy)) scale(1.1);opacity:0}
}

.card{
  position:relative;z-index:2;width:100%;max-width:560px;
  background:linear-gradient(170deg,rgba(255,245,248,0.97),rgba(255,236,242,0.97));
  color:var(--ink);border-radius:28px;padding:42px 32px 40px;
  box-shadow:0 30px 80px rgba(0,0,0,.45),0 0 0 1px rgba(255,255,255,.25) inset;
  text-align:center;
}
.eyebrow{
  font-size:13px;letter-spacing:3px;text-transform:uppercase;
  color:var(--rose-deep);font-weight:700;margin-bottom:16px;
}
.eyebrow .name{font-weight:800}
h1{font-size:clamp(26px,6vw,40px);line-height:1.15;font-weight:800;margin-bottom:24px}
h1 .wink{display:inline-block;animation:beat 1.6s ease-in-out infinite}
@keyframes beat{0%,100%{transform:scale(1)}50%{transform:scale(1.18)}}

.reasonBox{
  min-height:128px;display:flex;align-items:center;justify-content:center;
  background:#fdeef4;border:2px dashed #f3b6cd;border-radius:18px;
  padding:22px 18px;margin-bottom:26px;
}
.reason{
  font-size:clamp(18px,4.6vw,23px);font-weight:600;color:var(--ink);
  line-height:1.5;opacity:1;
}
.reason.fade{animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

.btn{
  background:linear-gradient(135deg,var(--rose),var(--rose-deep));
  color:#fff;border:none;font-size:clamp(18px,4.5vw,24px);font-weight:800;
  padding:18px 44px;border-radius:18px;cursor:pointer;
  box-shadow:0 14px 30px rgba(226,59,109,.5);
  transition:transform .15s ease,box-shadow .15s ease;letter-spacing:.3px;
}
.btn:hover{transform:scale(1.05);box-shadow:0 18px 40px rgba(226,59,109,.6)}
.btn:active{transform:scale(.97)}
.btn:focus-visible{outline:3px solid var(--gold);outline-offset:3px}

.counter{margin-top:16px;font-size:13px;font-weight:700;color:#b07;opacity:.7}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important;transition:none !important}
  .heart,.pop{display:none}
}
