@import url('https://fonts.googleapis.com/css2?family=VT323&family=Press+Start+2P&display=swap');

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'VT323', monospace;
  font-size: 20px;
  color: #4a2a6b;
  min-height: 100vh;
  background:
    radial-gradient(at 20% 10%, #ffd6f0 0%, transparent 50%),
    radial-gradient(at 85% 15%, #c8e7ff 0%, transparent 55%),
    radial-gradient(at 75% 85%, #e3d1ff 0%, transparent 55%),
    radial-gradient(at 15% 90%, #d6ffe9 0%, transparent 55%),
    linear-gradient(135deg, #fce4ff 0%, #e0f2ff 50%, #fce4ff 100%);
  background-attachment: fixed;
  overflow-x: hidden;
  cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20'><text x='0' y='16' font-size='18'>♡</text></svg>") 4 4, auto;
}

.stars {
  position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    radial-gradient(2px 2px at 10% 20%, #fff 50%, transparent 51%),
    radial-gradient(2px 2px at 30% 70%, #ffe6fa 50%, transparent 51%),
    radial-gradient(1px 1px at 60% 40%, #fff 50%, transparent 51%),
    radial-gradient(2px 2px at 80% 80%, #d6f0ff 50%, transparent 51%),
    radial-gradient(1px 1px at 90% 10%, #fff 50%, transparent 51%),
    radial-gradient(2px 2px at 45% 90%, #fff0fb 50%, transparent 51%);
  animation: twinkle 4s ease-in-out infinite alternate;
}
@keyframes twinkle { from {opacity:.4} to {opacity:1} }

.frame {
  position: relative; z-index: 1;
  max-width: 880px;
  margin: 24px auto;
  padding: 18px;
  background: rgba(255,255,255,0.55);
  border: 3px double #ff9ed6;
  border-radius: 18px;
  box-shadow: 0 0 0 4px #fff inset, 0 12px 40px rgba(180,120,200,.25);
  backdrop-filter: blur(6px);
}

.title { text-align: center; }
.marquee {
  overflow: hidden;
  background: linear-gradient(90deg, #ffb6e1, #b6e1ff, #d6b6ff, #ffb6e1);
  border: 2px solid #fff;
  border-radius: 999px;
  padding: 4px 0;
  margin-bottom: 10px;
  color: #fff;
  text-shadow: 1px 1px 0 #c46aa8;
}
.marquee span {
  display: inline-block;
  white-space: nowrap;
  padding-left: 100%;
  animation: scroll 22s linear infinite;
}
@keyframes scroll { to { transform: translateX(-100%); } }

h1 {
  font-family: 'Press Start 2P', monospace;
  font-size: 22px;
  margin: 8px 0 4px;
  color: #d957a8;
  text-shadow: 2px 2px 0 #fff, 4px 4px 0 #b6e1ff;
}
.sub { margin: 0 0 14px; color: #8a5ab0; }

.grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
@media (max-width: 640px) { .grid { grid-template-columns: 1fr; } }

.card {
  border: 2px solid #fff;
  border-radius: 14px;
  padding: 14px;
  box-shadow: 4px 4px 0 rgba(255,255,255,.7), 0 6px 20px rgba(180,120,200,.18);
}
.card h2 {
  font-family: 'Press Start 2P', monospace;
  font-size: 12px;
  margin: 0 0 10px;
  color: #fff;
  text-shadow: 1px 1px 0 #c46aa8;
}
.pink  { background: linear-gradient(160deg, #ffd0ec, #ffe8f5); }
.cyan  { background: linear-gradient(160deg, #cfeeff, #e6f7ff); }
.lilac { background: linear-gradient(160deg, #e3d1ff, #f1e6ff); }
.mint  { background: linear-gradient(160deg, #d4f7e3, #ecfdf3); }

.chibi {
  font-size: 42px;
  text-align: center;
  padding: 10px;
  cursor: pointer;
  user-select: none;
  transition: transform .15s;
}
.chibi:hover { transform: scale(1.1) rotate(-3deg); }

.bullets { padding-left: 18px; margin: 8px 0 0; }
.bullets li { line-height: 1.4; }

.btn {
  font-family: 'VT323', monospace;
  font-size: 18px;
  background: linear-gradient(180deg, #fff, #ffd6f0);
  color: #b03a82;
  border: 2px solid #ff9ed6;
  border-radius: 10px;
  padding: 6px 14px;
  cursor: pointer;
  box-shadow: 2px 2px 0 #c46aa8;
  transition: transform .08s;
}
.btn:hover { transform: translate(-1px,-1px); box-shadow: 3px 3px 0 #c46aa8; }
.btn:active { transform: translate(1px,1px); box-shadow: 1px 1px 0 #c46aa8; }

.counter { margin-top: 8px; }
.sparkle-field {
  position: relative;
  height: 80px;
  margin-top: 6px;
  overflow: hidden;
}
.sparkle-field .sp {
  position: absolute;
  font-size: 18px;
  animation: floatUp 1.6s ease-out forwards;
  pointer-events: none;
}
@keyframes floatUp {
  from { transform: translateY(80px) scale(.5); opacity: 0; }
  20%  { opacity: 1; }
  to   { transform: translateY(-10px) scale(1.2) rotate(20deg); opacity: 0; }
}

blockquote {
  margin: 6px 0;
  padding: 8px 12px;
  background: rgba(255,255,255,.6);
  border-left: 4px solid #d957a8;
  border-radius: 6px;
  min-height: 40px;
}

#gbForm { display: flex; flex-wrap: wrap; gap: 6px; }
#gbForm input {
  flex: 1 1 100px;
  font-family: 'VT323', monospace;
  font-size: 18px;
  padding: 4px 8px;
  border: 2px solid #9ed6ff;
  border-radius: 8px;
  background: #fff;
  color: #4a2a6b;
}
.gb { list-style: none; padding: 0; margin: 10px 0 0; max-height: 140px; overflow-y: auto; }
.gb li {
  background: rgba(255,255,255,.7);
  border: 1px dashed #9ed6ff;
  border-radius: 6px;
  padding: 4px 8px;
  margin-bottom: 4px;
}
.gb b { color: #2a7ab0; }
.tiny { font-size: 14px; color: #8a5ab0; margin: 4px 0 0; }

.webring {
  text-align: center;
  margin-top: 16px;
  padding: 8px;
  background: rgba(255,255,255,.5);
  border: 2px dashed #ff9ed6;
  border-radius: 10px;
  color: #8a5ab0;
}
.webring span { margin: 0 6px; }

#cursorTrail { position: fixed; inset: 0; pointer-events: none; z-index: 9999; }
#cursorTrail .heart {
  position: absolute;
  font-size: 14px;
  animation: fade 1s ease-out forwards;
}
@keyframes fade {
  from { opacity: 1; transform: translate(-50%, -50%) scale(1); }
  to   { opacity: 0; transform: translate(-50%, -120%) scale(.4); }
}
