:root{
  --bg: #0f1020;
  --panel: #151735;
  --text: #eaeaff;
  --muted: #b7b9d7;
  --primary: #8b5cf6;
  --accent: #22d3ee;
  --love: #ff5a8a;
}

*{box-sizing:border-box}
html,body{
  margin:0;
  padding:0;
  height:100%;
  background: radial-gradient(1200px 600px at 70% 0%, #1a1c3f 0%, var(--bg) 60%);
  color:var(--text);
  font-family: 'Poppins', 'Noto Serif SC', system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans CJK SC", sans-serif;
}

#app{min-height:100%;display:flex;flex-direction:column}

.hero{
  padding:96px 24px 48px;
  text-align:center;
}
.hero h1{
  font-size: clamp(36px, 6vw, 72px);
  line-height:1.05;
  margin:0 0 16px;
  letter-spacing: 0.5px;
}
.hero .highlight{color:var(--love);position:relative}
.hero .highlight::after{
  content:'';
  position:absolute;left:-4px;right:-4px;bottom:6px;height:10px;border-radius:6px;
  background: linear-gradient(90deg, var(--love), var(--accent));
  opacity:.35;filter: blur(3px);
  animation:pulse 2.8s ease-in-out infinite;
}
.subtitle{color:var(--muted);margin:0 auto 24px;max-width:720px}
.cta-row{display:flex;gap:12px;justify-content:center;align-items:center;flex-wrap:wrap}
.btn{border:1px solid transparent;padding:12px 18px;border-radius:12px;cursor:pointer;font-weight:600;transition:.2s}
.btn.primary{background:linear-gradient(135deg, var(--primary), var(--accent));color:#0b0c1a}
.btn.ghost{background:transparent;border-color:#2a2d58;color:var(--text)}
.btn:hover{transform:translateY(-1px);filter:brightness(1.05)}

.card-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;padding:24px;margin:0 24px}
.card{
  background: linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02));
  border:1px solid #2a2d58;border-radius:16px;padding:18px 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  backdrop-filter: blur(8px);
  transition: transform .2s ease, border-color .2s ease;
}
.card:hover{transform:translateY(-4px);border-color:#3b3f78}
.card h3{margin:0 0 8px}
.card p{margin:0;color:var(--muted)}

.story{padding:24px;margin:24px;border-top:1px dashed #2a2d58}
.story h2{margin:0 0 8px}
.story p{margin:0;color:var(--muted);max-width:760px}

.footer{margin-top:auto;padding:24px;text-align:center;color:#a6a9d3}

#confettiCanvas{position:fixed;inset:0;pointer-events:none}

@keyframes pulse{0%,100%{opacity:.35}50%{opacity:.6}}


