/* PokéRun — dunkles Handheld-Theme (Platzhalter; volle Visuals/Logo folgen). */
:root{
  --bg:#15171c; --bg2:#1d2026; --panel:#23272f; --edge:#33384280; --ink:#eef1f6; --ink2:#aab2c0;
  --candy:#ff5d8f; --accent:#5cc8ff; --a-btn:#ff5d6c; --b-btn:#ffc24b; --good:#6fe39b;
  --r:14px; --sh:0 6px 20px rgba(0,0,0,.4);
}
*{box-sizing:border-box;margin:0;-webkit-tap-highlight-color:transparent;user-select:none}
html,body{height:100%}
body{background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,sans-serif;
  display:flex;flex-direction:column;overflow:hidden;
  padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}
.btn{background:linear-gradient(180deg,#3a4150,#2b313c);color:var(--ink);border:1px solid var(--edge);
  border-radius:var(--r);padding:12px 18px;font-weight:700;font-size:1rem;cursor:pointer;box-shadow:var(--sh)}
.btn:active{transform:translateY(1px)}
.brand{font-weight:900;font-size:2.4rem;letter-spacing:-.02em}
.brand span{color:var(--candy)}
.brand.sm{font-size:1.2rem}

/* Gate */
.gate{position:fixed;inset:0;display:grid;place-items:center;background:radial-gradient(120% 80% at 50% 0%,#202531,#101216);z-index:10;padding:24px}
.gate-card{width:min(360px,90vw);text-align:center;display:flex;flex-direction:column;gap:14px}
.tagline{color:var(--ink2);margin-bottom:8px}
.gate input{background:var(--panel);border:1px solid var(--edge);border-radius:var(--r);padding:14px;color:var(--ink);font-size:1rem;text-align:center}
.err{color:var(--a-btn);min-height:1.2em;font-size:.9rem}

/* App-Layout */
#app{flex:1;display:flex;flex-direction:column;min-height:0}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:10px 16px}
.wallet{display:flex;align-items:center;gap:6px;background:var(--panel);border:1px solid var(--edge);
  border-radius:999px;padding:6px 14px}
.wallet b{font-size:1.1rem;color:var(--candy);font-variant-numeric:tabular-nums}
.wallet small{color:var(--ink2);font-size:.75rem;margin-left:4px}
.candy-ico{font-size:1.1rem}

/* Emulator-Bühne */
.stage{flex:1;display:grid;place-items:center;min-height:0;padding:8px}
.screen-frame{position:relative;width:100%;max-width:560px;aspect-ratio:240/160;background:#000;
  border-radius:12px;overflow:hidden;border:3px solid #0a0c10;box-shadow:var(--sh)}
#canvas{width:100%;height:100%;display:block;image-rendering:pixelated;background:#000}
.rom-prompt{position:absolute;inset:0;display:flex;flex-direction:column;gap:12px;align-items:center;justify-content:center;
  background:#13151b;text-align:center;padding:20px}
.rom-prompt .hint{color:var(--ink2);font-size:.85rem;max-width:30ch}
.chk{display:flex;align-items:center;gap:8px;color:var(--ink2);font-size:.9rem}

/* Controls */
.controls{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;
  padding:14px 18px calc(18px + env(safe-area-inset-bottom))}
.dpad{position:relative;width:132px;height:132px;justify-self:start}
.dpad .d{position:absolute;width:44px;height:44px;background:#2b313c;border:1px solid var(--edge);color:transparent}
.dpad .up{top:0;left:44px;border-radius:8px 8px 0 0}
.dpad .down{bottom:0;left:44px;border-radius:0 0 8px 8px}
.dpad .left{left:0;top:44px;border-radius:8px 0 0 8px}
.dpad .right{right:0;top:44px;border-radius:0 8px 8px 0}
.dpad::after{content:"";position:absolute;left:44px;top:44px;width:44px;height:44px;background:#2b313c}
.ab{display:flex;gap:16px;align-items:center;justify-self:end}
.face{width:64px;height:64px;border-radius:50%;border:none;color:#1a1d23;font-weight:900;font-size:1.4rem;box-shadow:var(--sh)}
.face.a{background:radial-gradient(circle at 35% 30%,#ff8a96,var(--a-btn))}
.face.b{background:radial-gradient(circle at 35% 30%,#ffd87a,var(--b-btn))}
.se{grid-column:1/-1;display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.pill{background:#2b313c;border:1px solid var(--edge);color:var(--ink2);border-radius:999px;padding:8px 16px;font-weight:700;font-size:.8rem}
.pill.run{background:linear-gradient(180deg,#ff6e9a,#e2477f);color:#fff;border:none}
.pressed{filter:brightness(1.5)}

/* Toast */
.toast{position:fixed;left:50%;bottom:calc(96px + env(safe-area-inset-bottom));transform:translateX(-50%) translateY(20px);
  background:#0c0e12;border:1px solid var(--edge);color:var(--ink);padding:12px 18px;border-radius:12px;
  opacity:0;pointer-events:none;transition:all .25s;z-index:20;max-width:88vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* Strava-Chip + Kopf-rechts */
.head-right{display:flex;align-items:center;gap:10px}
.strava-chip{background:#23272f;border:1px solid var(--edge);color:var(--ink2);border-radius:999px;
  padding:7px 13px;font-weight:800;font-size:.8rem;cursor:pointer;white-space:nowrap}
.strava-chip.on{background:#fc4c0233;border-color:#fc4c02;color:#ff7a45}

/* Feier-Overlay */
.celebrate{position:fixed;inset:0;z-index:30;display:grid;place-items:center;
  background:rgba(8,9,12,.78);backdrop-filter:blur(4px);padding:24px}
.cel-card{background:linear-gradient(180deg,#262b34,#1b1f26);border:1px solid var(--edge);
  border-radius:22px;padding:30px 26px;text-align:center;max-width:340px;width:100%;box-shadow:var(--sh);
  animation:celpop .4s cubic-bezier(.34,1.56,.64,1)}
@keyframes celpop{from{transform:scale(.8);opacity:0}}
.cel-emoji{font-size:3.4rem;animation:celbounce 1s ease-in-out infinite}
@keyframes celbounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.cel-card h2{margin:10px 0 6px;font-size:1.5rem;color:var(--ink)}
.cel-card p{color:var(--candy);font-weight:800;margin-bottom:18px}
.cel-card .btn{width:100%}

/* Profil-Wahl */
.player-list{display:flex;flex-direction:column;gap:8px;max-height:46vh;overflow:auto}
.player-pick{background:var(--panel);border:1px solid var(--edge);color:var(--ink);border-radius:var(--r);
  padding:14px;font-weight:800;font-size:1.05rem;cursor:pointer;text-align:center}
.player-pick:active{transform:translateY(1px)}
.player-new{display:flex;gap:8px;margin-top:6px}
.player-new input{flex:1;min-width:0;background:var(--panel);border:1px solid var(--edge);border-radius:var(--r);
  padding:14px;color:var(--ink);font-size:1rem}
.player-new .btn{white-space:nowrap}

/* TM-Zähler in der Leiste */
.tm-wrap{display:inline-flex;align-items:center;gap:4px;margin-left:8px;padding-left:8px;border-left:1px solid var(--edge)}
.tm-wrap b{color:var(--accent);font-variant-numeric:tabular-nums}
