/* ─────────────────────────────────────────────────────────────────────
   PokePad · Base — "SUNNY ROUTE" (light theme)
   Bright sky + cream, Pokédex red, grass green, sunny gold, Base blue.
   Chunky ink borders + hard arcade shadows (the GameBoy-box look) on a
   cheerful daylight backdrop. Bungee / Fredoka / Press Start 2P.
   ───────────────────────────────────────────────────────────────────── */
:root {
  /* surfaces */
  --bg: #eaf7ff;
  --sky: #bfe6ff;
  --cream: #fff7e2;
  --paper: #ffffff;
  --ink: #1c2b34;            /* dark slate — borders + headings */
  --ink-soft: #3a4d57;
  --glass: #ffffff;          /* card surface (kept name for play.css) */
  --glass-line: #d7e3ec;     /* card border */

  /* brand */
  --red: #ff3b46;
  --red-deep: #d81f2c;
  --red-dark: #c4101d;
  --green: #34c45f;
  --green-deep: #1e9b45;
  --green-glow: #1e9b45;     /* readable green on light */
  --screen: #9bbc0f;         /* DMG */
  --screen-dark: #0a1f0a;
  --gold: #ffc21f;
  --gold-deep: #e0a300;
  --base-blue: #1f6fff;
  --base-glow: #1f6fff;

  /* text */
  --text: #21323b;
  --muted: #5f7785;

  --pixel: "Press Start 2P", monospace;
  --display: "Bungee", "Press Start 2P", sans-serif;
  --read: "Fredoka", system-ui, sans-serif;

  --r: 16px;
  --shadow-hard: 5px 5px 0 var(--ink);
  --shadow-soft: 0 16px 34px -18px rgba(28,43,52,.4);
  --glow-red: 0 0 0 2px rgba(255,59,70,.18);
  --glow-green: 0 0 0 2px rgba(52,196,95,.22);
  --glow-blue: 0 0 0 2px rgba(31,111,255,.2);
  --maxw: 1200px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--read);
  font-weight: 500;
  color: var(--text);
  background:
    linear-gradient(180deg, var(--sky) 0%, #dff3ff 14%, var(--bg) 34%, #fff8ea 100%);
  background-attachment: fixed;
  min-height: 100svh;
  -webkit-font-smoothing: antialiased;
  position: relative;
  overflow-x: hidden;
}
/* soft cloud-dots up top */
body::before {
  content: ""; position: fixed; inset: 0 0 auto 0; height: 60vh; z-index: 0; pointer-events: none;
  background-image: radial-gradient(rgba(255,255,255,.7) 2px, transparent 3px);
  background-size: 34px 34px;
  mask-image: linear-gradient(180deg, rgba(0,0,0,.5), transparent);
  opacity: .5;
}
a { color: inherit; }
img { max-width: 100%; display: block; }

.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 22px; position: relative; z-index: 1; }
.pixel { font-family: var(--pixel); }
.display { font-family: var(--display); }

/* ── Header + ticker ────────────────────────────────────────────────── */
.site-top { position: sticky; top: 0; z-index: 50; }
.site-header {
  display: flex; align-items: center; gap: 20px; padding: 11px 22px;
  background: rgba(255,255,255,.86); backdrop-filter: blur(10px) saturate(1.3);
  border-bottom: 3px solid var(--ink);
}
.site-header .logo { display: flex; align-items: center; gap: 11px; text-decoration: none; }
.site-header .logo img { width: 32px; height: 32px; filter: drop-shadow(2px 2px 0 rgba(0,0,0,.15)); }
.site-header .logo b {
  font-family: var(--display); font-size: 17px; letter-spacing: .5px; color: var(--red-deep);
  text-shadow: 2px 2px 0 var(--gold);
}
.site-nav { display: flex; gap: 24px; margin-left: auto; }
.site-nav a {
  font-family: var(--pixel); font-size: 9px; text-decoration: none; color: var(--ink-soft);
  padding: 6px 2px; position: relative; transition: color .18s;
}
.site-nav a::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -4px; height: 3px; background: var(--red); transition: right .2s; }
.site-nav a:hover { color: var(--red-deep); } .site-nav a:hover::after { right: 0; }

.cta {
  font-family: var(--pixel); font-size: 10px; text-decoration: none; color: #fff;
  background: linear-gradient(180deg, var(--red), var(--red-deep));
  padding: 12px 16px; border-radius: 10px; border: 2px solid var(--ink);
  box-shadow: 3px 3px 0 var(--ink); transition: transform .08s, box-shadow .08s;
}
.cta:hover { transform: translate(-1px,-1px); box-shadow: 4px 4px 0 var(--ink); }
.cta:active { transform: translate(2px,2px); box-shadow: 1px 1px 0 var(--ink); }

.ticker-wrap {
  display: flex; align-items: stretch; height: 36px; overflow: hidden;
  background: linear-gradient(180deg, #173a17, #0c240c);
  border-bottom: 3px solid var(--ink);
}
.ticker-label {
  flex: none; display: flex; align-items: center; padding: 0 14px; font-family: var(--pixel);
  font-size: 9px; color: #fff; letter-spacing: 1px; background: var(--red); border-right: 2px solid #0c240c;
}
.ticker-label::before { content: ""; width: 7px; height: 7px; border-radius: 50%; margin-right: 8px; background: var(--screen); box-shadow: 0 0 8px var(--screen); animation: pulse 1.1s infinite; }
@keyframes pulse { 50% { opacity: .3; } }
.ticker-view { overflow: hidden; flex: 1; }
.ticker-track {
  display: inline-flex; gap: 28px; white-space: nowrap; align-items: center; height: 100%; padding-left: 20px;
  font-family: var(--pixel); font-size: 9px; color: var(--screen);
  animation: scroll var(--ticker-duration, 40s) linear infinite; will-change: transform;
}
.ticker-wrap:hover .ticker-track { animation-play-state: paused; }
@keyframes scroll { to { transform: translateX(-50%); } }
.ticker-item { display: inline-flex; align-items: center; gap: 7px; text-decoration: none; color: var(--screen); }
.ticker-item img { width: 18px; height: 18px; image-rendering: pixelated; }
.ticker-item.first { color: var(--gold); }
.ticker-item .star { color: var(--gold); }
.ticker-empty { color: #5f7f3f; font-family: var(--pixel); font-size: 9px; padding-left: 20px; }

/* ── Buttons ────────────────────────────────────────────────────────── */
.btn {
  font-family: var(--pixel); font-size: 11px; cursor: pointer; text-decoration: none;
  display: inline-flex; align-items: center; gap: 9px; padding: 14px 20px; border-radius: 12px;
  border: 3px solid var(--ink); box-shadow: var(--shadow-hard); transition: transform .08s, box-shadow .08s, filter .2s;
}
.btn-red { background: linear-gradient(180deg, var(--red), var(--red-deep)); color: #fff; }
.btn-gold { background: linear-gradient(180deg, #ffd95e, var(--gold)); color: #3a2a00; }
.btn-ghost { background: var(--paper); color: var(--ink); }
.btn:hover { transform: translate(-2px,-2px); box-shadow: 7px 7px 0 var(--ink); }
.btn:active { transform: translate(2px,2px); box-shadow: 2px 2px 0 var(--ink); }

/* Pokéball arcade CTA */
.btn-ball {
  position: relative; width: 126px; height: 126px; border-radius: 50%; cursor: pointer; text-decoration: none;
  background: linear-gradient(180deg, var(--red) 0 46%, var(--ink) 46% 54%, #fafafa 54% 100%);
  border: 4px solid var(--ink); display: grid; place-items: center;
  box-shadow: var(--shadow-hard); animation: bob 2.6s ease-in-out infinite; transition: transform .15s;
}
@keyframes bob { 50% { transform: translateY(-8px); } }
.btn-ball:hover { transform: scale(1.06); }
.btn-ball::after { content: ""; position: absolute; width: 38px; height: 38px; border-radius: 50%; background: #fff; border: 4px solid var(--ink); }
.btn-ball span { position: relative; z-index: 2; font-family: var(--pixel); font-size: 11px; color: var(--ink); background: #fff; padding: 4px 7px; border: 2px solid var(--ink); border-radius: 3px; }

/* ── Sections / panels ──────────────────────────────────────────────── */
.section { padding: 64px 0; position: relative; z-index: 1; }
.panel { background: var(--paper); border: 3px solid var(--ink); border-radius: var(--r); box-shadow: var(--shadow-hard); }
.section-head { text-align: center; margin-bottom: 36px; }
.section-head .kicker { font-family: var(--pixel); font-size: 9px; color: var(--green-deep); letter-spacing: 2px; }
.section-head h2 { font-family: var(--display); font-size: clamp(26px, 4vw, 40px); margin: 12px 0 8px; color: var(--ink); text-shadow: 2px 2px 0 rgba(255,194,31,.5); }
.section-head p { color: var(--muted); margin: 0; font-size: 16px; }

/* ── Footer ─────────────────────────────────────────────────────────── */
.foot { margin-top: 30px; border-top: 3px solid var(--ink); background: #fffdf6; padding: 44px 0 22px; position: relative; z-index: 1; }
.foot .cols { display: grid; grid-template-columns: 1.5fr repeat(3, 1fr); gap: 28px; }
.foot h4 { font-family: var(--pixel); font-size: 9px; color: var(--red-deep); margin: 0 0 14px; letter-spacing: 1px; }
.foot a { display: block; color: var(--ink-soft); text-decoration: none; margin: 7px 0; }
.foot a:hover { color: var(--red-deep); }
.foot .brand b { font-family: var(--display); font-size: 18px; color: var(--ink); }
.foot .bottom { margin-top: 28px; padding-top: 16px; border-top: 2px dashed var(--glass-line); display: flex; justify-content: space-between; flex-wrap: wrap; gap: 8px; font-size: 13px; color: var(--muted); }

@media (max-width: 820px) { .site-nav { display: none; } .foot .cols { grid-template-columns: 1fr 1fr; } }
