/* LCD Classics — playful sticker-style site. Palette from the PLAYTIME logo:
   red #E23B34, blue #3B8DDE, green #6DBE45, yellow #F6C93F, navy #17356B, cream #FDF4E3 */

* { margin: 0; padding: 0; box-sizing: border-box; }

:root {
  --red: #E23B34; --blue: #3B8DDE; --green: #6DBE45; --yellow: #F6C93F;
  --navy: #17356B; --cream: #FDF4E3; --paper: #FFFBF2;
}

body {
  font-family: 'Fredoka', 'Arial Rounded MT Bold', system-ui, sans-serif;
  background: var(--cream);
  color: var(--navy);
  overflow-x: hidden;
}

/* polka-dot paper background */
body::before {
  content: ''; position: fixed; inset: 0; z-index: -1;
  background-image: radial-gradient(rgba(23,53,107,.05) 12%, transparent 13%);
  background-size: 42px 42px;
}

h1, h2, h3 { font-family: 'Baloo 2', 'Fredoka', sans-serif; }

/* ---------- hero ---------- */
.hero {
  position: relative; text-align: center;
  padding: 42px 20px 90px; overflow: hidden;
  background: linear-gradient(#BFE3FF 0%, #E8F4FF 55%, var(--cream) 100%);
}
.sunburst {
  position: absolute; left: 50%; top: 260px; width: 1600px; height: 1600px;
  transform: translate(-50%, -50%);
  background: repeating-conic-gradient(rgba(246,201,63,.22) 0 9deg, transparent 9deg 22.5deg);
  border-radius: 50%;
  animation: spin 80s linear infinite;
  pointer-events: none;
}
@keyframes spin { to { transform: translate(-50%, -50%) rotate(360deg); } }

.brand-logo { position: relative; width: min(300px, 62vw); }
.floaty { animation: floaty 4s ease-in-out infinite; }
@keyframes floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-12px); } }

.rainbow-title {
  position: relative;
  font-size: clamp(46px, 9vw, 108px);
  font-weight: 800; letter-spacing: .02em; line-height: 1.05; margin-top: 8px;
  -webkit-text-stroke: 2px #fff;
  text-shadow: 0 4px 0 rgba(23,53,107,.9), 0 7px 14px rgba(23,53,107,.35);
}
.rainbow-title .sp { display: inline-block; width: .35em; }
.c1 { color: var(--red); } .c2 { color: var(--blue); }
.c3 { color: var(--green); } .c4 { color: var(--yellow); }

.tagline {
  position: relative; margin: 14px auto 26px;
  font-size: clamp(16px, 2.6vw, 24px); font-weight: 600; color: #2b4a86;
}

.hero-device {
  position: relative; width: min(860px, 92vw); margin-top: 38px;
  border-radius: 22px; transform: rotate(-2deg);
  border: 5px solid #fff; outline: 4px solid var(--navy);
  box-shadow: 0 24px 60px rgba(23,53,107,.4);
}
.wobble-hover { transition: transform .3s; }
.wobble-hover:hover { transform: rotate(0deg) scale(1.02); }

/* ---------- buttons ---------- */
.store-buttons {
  position: relative; display: flex; gap: 16px; justify-content: center;
  flex-wrap: wrap; margin-top: 10px;
}
.btn {
  display: inline-block; padding: 16px 30px; border-radius: 999px;
  font-family: 'Baloo 2', sans-serif; font-weight: 800;
  font-size: clamp(16px, 2.4vw, 21px); text-decoration: none;
  border: 4px solid var(--navy); box-shadow: 0 6px 0 var(--navy);
  transition: transform .12s, box-shadow .12s;
}
.btn-play { background: var(--green); color: #fff; }
.btn-play:hover { transform: translateY(3px); box-shadow: 0 3px 0 var(--navy); }
.btn-icon { display: inline-block; margin-right: 6px; }
.btn-soon { background: #e9e2d2; color: #7d7464; cursor: default; }

/* ---------- sections ---------- */
main { max-width: 1180px; margin: 0 auto; padding: 0 18px; }

section {
  background: var(--paper); border: 4px solid var(--navy); border-radius: 30px;
  box-shadow: 0 10px 0 rgba(23,53,107,.18);
  padding: 46px clamp(20px, 5vw, 60px); margin: 46px 0; text-align: center;
  position: relative;
}
.section-badge {
  position: absolute; top: -20px; left: 50%; transform: translateX(-50%) rotate(-2deg);
  background: var(--yellow); border: 3px solid var(--navy); border-radius: 999px;
  padding: 6px 22px; font-weight: 700; font-size: 15px; white-space: nowrap;
}
section h2 {
  font-size: clamp(34px, 6vw, 58px); font-weight: 800; color: var(--red);
  text-shadow: 0 3px 0 rgba(23,53,107,.85);
  -webkit-text-stroke: 1.5px #fff;
}
#chaser h2 { letter-spacing: .06em; }
.lead {
  max-width: 760px; margin: 14px auto 8px;
  font-size: clamp(16px, 2.3vw, 20px); font-weight: 500; line-height: 1.55;
}

/* features */
.feature-row {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 18px; margin: 34px 0 10px;
}
.feature {
  background: #fff; border: 3px solid var(--navy); border-radius: 22px;
  padding: 22px 16px; box-shadow: 0 6px 0 rgba(23,53,107,.15);
}
.feature:nth-child(1) { background: #FFF1EF; }
.feature:nth-child(2) { background: #EFF6FF; }
.feature:nth-child(3) { background: #F1FAEB; }
.feature:nth-child(4) { background: #FFF9E6; }
.fico { font-size: 44px; line-height: 1; }
.feature h3 { font-size: 22px; margin: 10px 0 6px; }
.feature p { font-size: 15px; line-height: 1.45; }

.bounce-in { animation: pop .6s cubic-bezier(.2,1.6,.4,1) both; }
.d1 { animation-delay: .08s; } .d2 { animation-delay: .16s; } .d3 { animation-delay: .24s; }
@keyframes pop { from { transform: scale(.7); opacity: 0; } to { transform: scale(1); opacity: 1; } }

/* gallery */
.gallery {
  display: flex; gap: 16px; overflow-x: auto; padding: 18px 4px;
  scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch;
}
.gallery img {
  width: min(640px, 84vw); flex: 0 0 auto; scroll-snap-align: center;
  border-radius: 18px; border: 4px solid var(--navy);
  box-shadow: 0 8px 18px rgba(23,53,107,.25);
}
.swipe-hint { font-size: 14px; color: #8a7f68; margin-bottom: 20px; }

/* coming soon */
.coming h2 { color: var(--blue); }
.mystery-row { display: flex; gap: 22px; justify-content: center; flex-wrap: wrap; margin-top: 26px; }
.mystery {
  width: 150px; padding: 26px 10px 18px;
  background: repeating-linear-gradient(45deg, #fff 0 14px, #f4ecd9 14px 28px);
  border: 3px dashed var(--navy); border-radius: 20px;
}
.mystery span {
  font-family: 'Baloo 2', sans-serif; font-size: 64px; font-weight: 800; color: var(--yellow);
  text-shadow: 0 3px 0 var(--navy);
}
.mystery p { font-weight: 600; margin-top: 6px; }
.tilt-l { transform: rotate(-4deg); } .tilt-r { transform: rotate(4deg); }

.about h2 { color: var(--green); }

/* ---------- footer ---------- */
footer {
  text-align: center; padding: 40px 20px 60px; color: #6b6046;
  font-size: 15px; line-height: 1.9;
}
.foot-logo { width: 150px; opacity: .9; }
footer a { color: var(--blue); font-weight: 600; }

@media (max-width: 640px) {
  .hero { padding-top: 28px; }
  .hero-device { transform: rotate(0); }
}
