/* ============ RL RPG — Design System (telas aprovadas) ============ */
:root{
  --bg-base:#0A0A12; --bg-card:#12121F; --bg-card-glass:rgba(18,18,31,.78);
  --border-card:rgba(138,99,255,.25);
  --neon-purple:#8B5CF6; --neon-magenta:#E935C1; --neon-cyan:#22D3EE; --neon-blue:#3B82F6;
  --gold:#F5B921; --gem:#A78BFA; --energy:#38BDF8; --hp:#F43F5E;
  --rare-common:#9CA3AF; --rare-rare:#3B82F6; --rare-epic:#A855F7; --rare-legendary:#F59E0B;
  --text-1:#F4F4F8; --text-2:#9D9DB5;
  --glow-purple:0 0 18px rgba(139,92,246,.45); --glow-cyan:0 0 14px rgba(34,211,238,.4);
  --r-card:16px; --r-btn:12px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%}
body{
  background:var(--bg-base) radial-gradient(1200px 600px at 50% -10%, rgba(139,92,246,.16), transparent 60%);
  color:var(--text-1); font-family:'Inter',system-ui,-apple-system,sans-serif;
  -webkit-font-smoothing:antialiased; padding-bottom:88px;
}
a{color:var(--neon-cyan);text-decoration:none}
.container{max-width:520px;margin:0 auto;padding:16px}

/* ---- componentes ---- */
.card{background:var(--bg-card);border:1px solid var(--border-card);border-radius:var(--r-card);padding:16px;margin-bottom:14px}
.card-glass{background:var(--bg-card-glass);backdrop-filter:blur(8px)}
.row{display:flex;align-items:center;gap:10px}
.between{justify-content:space-between}
.muted{color:var(--text-2);font-size:.82rem}
.section-title{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-2);margin:18px 0 10px;display:flex;justify-content:space-between;align-items:center}
.section-title a{font-size:.72rem;color:var(--neon-cyan)}

.btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px;border:0;border-radius:var(--r-btn);
  font-size:1rem;font-weight:700;cursor:pointer;color:#fff;transition:transform .1s, box-shadow .2s}
.btn:active{transform:scale(.98)}
.btn-primary{background:linear-gradient(90deg,var(--neon-purple),var(--neon-blue));box-shadow:var(--glow-purple)}
.btn-ghost{background:transparent;border:1px solid var(--border-card);color:var(--text-1)}
.btn-sm{width:auto;padding:8px 16px;font-size:.85rem}
.btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}

.input-group{position:relative;margin-bottom:14px}
.input-group input,.input-group select{
  width:100%;padding:15px 16px 15px 46px;background:rgba(10,10,18,.6);
  border:1px solid var(--border-card);border-radius:var(--r-btn);color:var(--text-1);font-size:1rem;outline:none}
.input-group input:focus,.input-group select:focus{border-color:var(--neon-purple);box-shadow:var(--glow-purple)}
.input-group .icon{position:absolute;left:15px;top:50%;transform:translateY(-50%);color:var(--text-2);font-size:1rem}
.input-group select{padding-left:16px}

.pill{display:inline-flex;align-items:center;gap:6px;background:var(--bg-card);border:1px solid var(--border-card);
  border-radius:999px;padding:6px 12px;font-size:.85rem;font-weight:700}
.pill .gold{color:var(--gold)} .pill .gem{color:var(--gem)} .pill .energy{color:var(--energy)}

.progress{height:8px;background:rgba(255,255,255,.08);border-radius:99px;overflow:hidden}
.progress > div{height:100%;border-radius:99px;background:linear-gradient(90deg,var(--neon-cyan),var(--neon-purple));box-shadow:var(--glow-cyan);transition:width .4s}
.progress.hp > div{background:linear-gradient(90deg,var(--hp),var(--neon-magenta))}
.progress.energy > div{background:linear-gradient(90deg,var(--energy),var(--neon-cyan))}

.avatar{width:64px;height:64px;border-radius:50%;border:2px solid var(--neon-purple);box-shadow:var(--glow-purple);
  background:linear-gradient(135deg,#1b1530,#0e0e1c);display:flex;align-items:center;justify-content:center;
  font-weight:800;font-size:1.3rem;color:var(--neon-magenta);position:relative;flex-shrink:0}
.avatar .lvl{position:absolute;bottom:-6px;left:50%;transform:translateX(-50%);background:var(--bg-card);
  border:1px solid var(--neon-purple);border-radius:8px;font-size:.65rem;padding:1px 7px;color:var(--text-1)}

.quest-card{border-left:3px solid var(--gold);cursor:pointer}
.quest-card.epic{border-left-color:var(--rare-epic)}
.quest-card.rare{border-left-color:var(--rare-rare)}
.quest-card h4{font-size:.95rem;margin-bottom:3px}
.quest-rewards{display:flex;gap:14px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(255,255,255,.06);font-size:.8rem}
.quest-rewards .xp{color:var(--neon-cyan);font-weight:700}
.quest-rewards .gold{color:var(--gold);font-weight:700}
.quest-rewards .gem{color:var(--gem);font-weight:700}
.dist{font-size:.78rem;color:var(--text-2);white-space:nowrap}

.badge{font-size:.65rem;background:var(--neon-magenta);color:#fff;border-radius:99px;padding:1px 7px;font-weight:700}
.stat-row{display:flex;align-items:center;justify-content:space-between;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.05)}
.stat-row:last-child{border:none}
.stat-row .plus{width:26px;height:26px;border-radius:8px;border:1px solid var(--neon-purple);background:transparent;
  color:var(--neon-purple);font-weight:800;cursor:pointer}

/* ---- bottom nav ---- */
.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:50;display:flex;justify-content:space-around;align-items:flex-end;
  background:rgba(10,10,18,.92);backdrop-filter:blur(12px);border-top:1px solid var(--border-card);padding:8px 4px calc(8px + env(safe-area-inset-bottom))}
.bottom-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;color:var(--text-2);font-size:.62rem;
  letter-spacing:.05em;text-transform:uppercase;flex:1;padding:4px 0}
.bottom-nav a.active{color:var(--neon-purple)}
.bottom-nav a .ico{font-size:1.25rem}
.bottom-nav .fab{margin-top:-30px;flex:0 0 72px}
.bottom-nav .fab .scan{width:62px;height:62px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 30% 30%, #1c1430, #0c0c18);border:2px solid var(--neon-purple);
  box-shadow:var(--glow-purple);font-size:1.5rem}

/* ---- login hero ---- */
.login-hero{min-height:46vh;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:40px 20px 10px;
  background:radial-gradient(600px 300px at 50% 0%, rgba(233,53,193,.18), transparent 70%)}
.logo-rl{font-size:4.2rem;font-weight:900;font-style:italic;letter-spacing:-.04em;
  background:linear-gradient(100deg,var(--neon-magenta) 20%,var(--neon-purple) 50%,var(--neon-cyan) 85%);
  -webkit-background-clip:text;background-clip:text;color:transparent;filter:drop-shadow(0 0 22px rgba(233,53,193,.5));line-height:1}
.logo-sub{letter-spacing:.42em;font-size:.95rem;font-weight:600;margin-top:6px}
.tagline{color:var(--text-2);margin-top:14px;font-size:.95rem;line-height:1.5}

.toast{position:fixed;top:14px;left:50%;transform:translateX(-50%);z-index:99;background:var(--bg-card);
  border:1px solid var(--neon-purple);box-shadow:var(--glow-purple);border-radius:var(--r-btn);
  padding:12px 18px;font-size:.88rem;max-width:90%;opacity:0;transition:opacity .25s;pointer-events:none}
.toast.show{opacity:1}
.toast.err{border-color:var(--hp)}

#map{position:fixed;inset:0;bottom:80px;z-index:1}
.map-sheet{position:fixed;left:0;right:0;bottom:80px;z-index:40;background:var(--bg-card-glass);backdrop-filter:blur(10px);
  border-top:1px solid var(--border-card);border-radius:18px 18px 0 0;padding:16px;transform:translateY(110%);transition:transform .25s}
.map-sheet.open{transform:translateY(0)}
.hidden{display:none!important}
.center{text-align:center}
.mt{margin-top:14px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
