/* ============================================================
   Gamificação da Robótica Educacional — game launcher vibe
   Foco: crianças 8+ (energia de plataforma de jogos) + educadores.
   Tema escuro vibrante, mundos coloridos, cards chunky, movimento.
   ============================================================ */

/* Space Grotesk self-hospedada (sem Google Fonts / terceiros) */
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:300 700;font-display:swap;
  src:url('/gamehub/assets/fonts/SpaceGrotesk-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD;}
@font-face{font-family:'Space Grotesk';font-style:normal;font-weight:300 700;font-display:swap;
  src:url('/gamehub/assets/fonts/SpaceGrotesk-latin-ext.woff2') format('woff2');
  unicode-range:U+0100-02AF,U+0304,U+0308,U+0329,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF;}

:root{
  --bg:#0a1330; --bg2:#0b1b3d; --panel:#122046; --panel2:#16265a;
  --ink:#f2f5ff; --muted:#a9b2d8; --hair:rgba(255,255,255,.09); --hair2:rgba(255,255,255,.16);
  --p1:#2f6bff; --p2:#22d3ee; --p3:#ffb020; --yellow:#fbbf24; --green:#34d399; --orange:#fb923c; --blue:#3b82f6;
  --grad:linear-gradient(120deg,#2f6bff,#22d3ee 55%,#34d399);
  --grad-warm:linear-gradient(120deg,#f7941e,#fbbf24 50%,#2f6bff);
  --shadow:0 24px 70px -24px rgba(0,0,0,.7);
  --radius:26px;
}

/* Cores por categoria (mundos) */
.cat-primeiros  { --c1:#34d399; --c2:#22d3ee; }
.cat-amazonia   { --c1:#22c55e; --c2:#84cc16; }
.cat-competicoes{ --c1:#3b82f6; --c2:#22d3ee; }
.cat-cirdi      { --c1:#fbbf24; --c2:#fb923c; }
.cat-pesca      { --c1:#06b6d4; --c2:#3b82f6; }
.cat-logica     { --c1:#a855f7; --c2:#f472b6; }
.cat-cultura    { --c1:#fb923c; --c2:#f59e0b; }

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  background:var(--bg);color:var(--ink);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;
  background-image:
    radial-gradient(1100px 700px at 12% -8%, rgba(47,107,255,.40), transparent 60%),
    radial-gradient(1000px 680px at 92% 4%, rgba(34,211,238,.26), transparent 62%),
    radial-gradient(900px 700px at 50% 108%, rgba(251,176,32,.16), transparent 60%);
  background-attachment:fixed;
}
h1,h2,h3,.font-head{font-family:'Space Grotesk',system-ui,sans-serif;letter-spacing:-.02em;line-height:1.08}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1220px;margin:0 auto;padding:0 22px}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.grad-text.warm{background:var(--grad-warm);-webkit-background-clip:text;background-clip:text;color:transparent}
.eyebrow{display:inline-block;font-size:.74rem;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--p2)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---------- Botões ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-weight:800;font-size:1rem;
  padding:.95rem 1.7rem;border-radius:999px;border:2px solid transparent;cursor:pointer;font-family:inherit;
  transition:transform .16s ease,box-shadow .16s ease,background .16s ease;white-space:nowrap;text-align:center}
.btn:hover{transform:translateY(-3px) scale(1.02)}
.btn:active{transform:translateY(-1px) scale(.99)}
.btn-primary{background:linear-gradient(135deg,#2f6bff,#4b8bff);color:#fff;box-shadow:0 16px 38px -12px rgba(47,107,255,.8)}
.btn-cyan{background:linear-gradient(135deg,#22d3ee,#3b82f6);color:#04121f;box-shadow:0 16px 38px -12px rgba(34,211,238,.7)}
.btn-ghost{background:rgba(255,255,255,.05);border-color:var(--hair2);color:var(--ink)}
.btn-ghost:hover{background:rgba(255,255,255,.1)}
.btn-lg{font-size:1.1rem;padding:1.1rem 2rem}

/* ---------- Top bar ---------- */
.topbar{position:sticky;top:0;z-index:40;backdrop-filter:blur(14px);
  background:linear-gradient(180deg,rgba(11,16,41,.92),rgba(11,16,41,.66));border-bottom:1px solid var(--hair)}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;height:68px;gap:16px}
.brand{display:flex;align-items:center;gap:.7rem;font-weight:800}
.brand .logo{font-size:1.7rem;filter:drop-shadow(0 4px 10px rgba(47,107,255,.5));animation:bob 3.2s ease-in-out infinite}
.brand .bt{display:flex;flex-direction:column;line-height:1.05}
.brand .bt b{font-family:'Space Grotesk',sans-serif;font-size:1.02rem;letter-spacing:-.01em}
.brand .bt span{font-size:.7rem;color:var(--muted);font-weight:600;letter-spacing:.02em}
.topbar .links{display:flex;align-items:center;gap:18px}
.topbar .links a{font-size:.92rem;font-weight:700;color:var(--muted);transition:color .15s}
.topbar .links a:hover{color:var(--ink)}
@media(max-width:760px){.topbar .links a.hide-sm{display:none}}

/* ---------- HERO (apresentação) ---------- */
.hero{position:relative;padding:64px 0 36px;overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:center}
@media(max-width:900px){.hero-grid{grid-template-columns:1fr;text-align:center}}
.hero h1{font-size:clamp(2.4rem,6vw,4.3rem);font-weight:800;margin:.4rem 0 .2rem}
.hero .lead{font-size:clamp(1.05rem,2.2vw,1.3rem);color:var(--muted);max-width:620px;margin:.6rem 0 1.4rem}
@media(max-width:900px){.hero .lead{margin-left:auto;margin-right:auto}}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:900px){.hero-cta{justify-content:center}}
.hero-stats{display:flex;gap:26px;margin-top:26px;flex-wrap:wrap}
@media(max-width:900px){.hero-stats{justify-content:center}}
.hero-stats .st b{font-family:'Space Grotesk',sans-serif;font-size:1.7rem;display:block;line-height:1}
.hero-stats .st span{font-size:.8rem;color:var(--muted);font-weight:600}

/* mascote / arte do hero */
.hero-art{position:relative;display:flex;align-items:center;justify-content:center;min-height:300px}
.hero-bot{font-size:clamp(8rem,20vw,13rem);filter:drop-shadow(0 30px 50px rgba(47,107,255,.55));animation:float 5s ease-in-out infinite;z-index:2}
.hero-art .orb{position:absolute;border-radius:50%;filter:blur(2px);opacity:.85;animation:float 6s ease-in-out infinite}
.hero-art .o1{width:74px;height:74px;background:radial-gradient(circle at 30% 30%,#34d399,#059669);top:6%;left:8%;animation-delay:.2s}
.hero-art .o2{width:54px;height:54px;background:radial-gradient(circle at 30% 30%,#fbbf24,#f59e0b);bottom:10%;left:18%;animation-delay:1.1s}
.hero-art .o3{width:64px;height:64px;background:radial-gradient(circle at 30% 30%,#f472b6,#db2777);top:14%;right:10%;animation-delay:.6s}
.hero-art .o4{width:44px;height:44px;background:radial-gradient(circle at 30% 30%,#22d3ee,#0891b2);bottom:16%;right:18%;animation-delay:1.5s}
.hero-art .spark{position:absolute;font-size:1.6rem;animation:twinkle 2.6s ease-in-out infinite}
.hero-art .s1{top:0;right:30%}.hero-art .s2{bottom:4%;left:38%;animation-delay:1s}

/* ---------- Faixa de benefícios ---------- */
.why{padding:30px 0 8px}
.why-head{text-align:center;max-width:760px;margin:0 auto 26px}
.why-head h2{font-size:clamp(1.7rem,4vw,2.5rem);margin-bottom:.5rem}
.why-head p{color:var(--muted);font-size:1.05rem}
.why-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
@media(max-width:900px){.why-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:520px){.why-grid{grid-template-columns:1fr}}
.why-card{background:linear-gradient(160deg,var(--panel),var(--panel2));border:1px solid var(--hair);
  border-radius:var(--radius);padding:22px 20px;transition:transform .18s ease,border-color .18s}
.why-card:hover{transform:translateY(-4px);border-color:var(--hair2)}
.why-card .ic{font-size:2.2rem;margin-bottom:.5rem;display:block}
.why-card h3{font-size:1.12rem;margin-bottom:.3rem}
.why-card p{font-size:.92rem;color:var(--muted)}

.papert{margin:30px auto 0;max-width:900px;background:linear-gradient(135deg,rgba(47,107,255,.16),rgba(34,211,238,.1));
  border:1px solid var(--hair2);border-radius:var(--radius);padding:24px 26px;text-align:center}
.papert p{font-size:1.05rem;color:#dfe6ff}
.papert b{color:var(--p2)}

/* ---------- Galeria ---------- */
.gallery{padding:48px 0 30px}
.gallery-head{text-align:center;margin-bottom:22px}
.gallery-head h2{font-size:clamp(1.8rem,4.5vw,2.7rem)}
.gallery-head p{color:var(--muted);margin-top:.4rem}

.toolbar{position:sticky;top:68px;z-index:30;padding:10px 0;margin-bottom:6px;
  background:linear-gradient(180deg,rgba(11,16,41,.96),rgba(11,16,41,.7));backdrop-filter:blur(12px);border-radius:16px}
/* Busca abaixo dos botões, mais compacta */
.search{position:relative;max-width:460px;margin:10px auto 0}
.search input{width:100%;padding:.62rem .9rem .62rem 2.7rem;border-radius:999px;border:2px solid var(--hair2);
  background:rgba(255,255,255,.05);color:var(--ink);font-size:.92rem;font-family:inherit;transition:border-color .15s,background .15s}
.search input::placeholder{color:var(--muted)}
.search input:focus{outline:none;border-color:var(--p1);background:rgba(255,255,255,.08)}
.search .mag{position:absolute;left:.95rem;top:50%;transform:translateY(-50%);font-size:1.05rem;opacity:.8}
.chips{display:flex;gap:7px;flex-wrap:wrap;justify-content:center}
.chip{display:inline-flex;align-items:center;gap:.35rem;padding:.34rem .72rem;border-radius:999px;cursor:pointer;
  border:1px solid var(--hair2);background:rgba(255,255,255,.04);color:var(--ink);font-weight:700;font-size:.82rem;
  font-family:inherit;transition:transform .14s,border-color .14s,background .14s}
.chip:hover{transform:translateY(-2px);border-color:var(--hair2);background:rgba(255,255,255,.09)}
.chip .n{font-size:.68rem;opacity:.7;font-weight:800}
.chip[aria-pressed="true"]{background:linear-gradient(135deg,var(--p1),var(--p3));border-color:transparent;color:#fff;
  box-shadow:0 10px 22px -12px rgba(47,107,255,.7)}

.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:20px;margin-top:18px}
.card{position:relative;background:linear-gradient(165deg,var(--panel),var(--panel2));border:1px solid var(--hair);
  border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;cursor:pointer;
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s}
.card:hover{transform:translateY(-7px);border-color:var(--c1);box-shadow:0 26px 60px -22px var(--c1)}
.card:focus-visible{outline:3px solid var(--p2);outline-offset:3px}
.card .thumb{position:relative;height:152px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--c1),var(--c2));overflow:hidden}
.card .thumb::after{content:"";position:absolute;inset:0;z-index:0;
  background-image:radial-gradient(circle at 20% 20%,rgba(255,255,255,.22),transparent 30%),
    radial-gradient(circle at 80% 70%,rgba(0,0,0,.16),transparent 40%);}
.card .thumb .big{font-size:4.2rem;filter:drop-shadow(0 8px 16px rgba(0,0,0,.3));z-index:0;transition:transform .25s}
.card:hover .thumb .big{transform:scale(1.12) rotate(-5deg)}
/* Thumbnail real do jogo (cobre o emoji-fallback; removido via onerror se faltar) */
.card .thumb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;transition:transform .35s ease}
.card:hover .thumb-img{transform:scale(1.07)}
.card .scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to top,rgba(3,9,26,.5),transparent 42%),linear-gradient(to bottom,rgba(3,9,26,.34),transparent 32%)}
.card .type{position:absolute;top:10px;right:10px;z-index:2;font-size:.68rem;font-weight:800;letter-spacing:.04em;
  padding:.25rem .55rem;border-radius:999px;background:rgba(0,0,0,.42);color:#fff;backdrop-filter:blur(4px)}
.card .catpill{position:absolute;top:10px;left:10px;z-index:2;font-size:.68rem;font-weight:800;
  padding:.25rem .55rem;border-radius:999px;background:rgba(0,0,0,.42);color:#fff;backdrop-filter:blur(4px)}
.card .body{padding:16px 16px 18px;display:flex;flex-direction:column;gap:.5rem;flex:1}
.card .body h3{font-size:1.05rem;line-height:1.18}
.card .body p{font-size:.86rem;color:var(--muted);flex:1}
.card .play{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;margin-top:.3rem;
  padding:.6rem 1rem;border-radius:999px;font-weight:800;font-size:.9rem;
  background:linear-gradient(135deg,var(--c1),var(--c2));color:#06121f;transition:filter .15s}
.card:hover .play{filter:brightness(1.08)}
.featured-flag{position:absolute;top:10px;left:50%;transform:translateX(-50%);z-index:3;font-size:.66rem;font-weight:800;
  letter-spacing:.06em;padding:.22rem .6rem;border-radius:999px;background:linear-gradient(135deg,#fbbf24,#fb923c);color:#3a1d00;
  box-shadow:0 6px 16px -6px rgba(251,191,36,.8)}
.empty{text-align:center;padding:50px 20px;color:var(--muted)}
.empty .ic{font-size:3rem;display:block;margin-bottom:.4rem}

/* ---------- Footer ---------- */
.footer{margin-top:40px;border-top:1px solid var(--hair);background:rgba(0,0,0,.18)}
.footer .wrap{padding:34px 22px;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px}
@media(max-width:760px){.footer .wrap{grid-template-columns:1fr;text-align:center}}
.footer h4{font-family:'Space Grotesk',sans-serif;font-size:1rem;margin-bottom:.6rem}
.footer p,.footer a{font-size:.9rem;color:var(--muted);margin-bottom:.3rem}
.footer a:hover{color:var(--ink)}
.footer .copy{grid-column:1/-1;border-top:1px solid var(--hair);padding-top:16px;margin-top:8px;font-size:.82rem;color:var(--muted);text-align:center}

/* ---------- PLAYER overlay ---------- */
.player{position:fixed;inset:0;z-index:90;display:none;flex-direction:column;background:#05060f}
.player.open{display:flex}
.player-bar{display:flex;align-items:center;gap:8px;height:46px;padding:0 12px;
  background:linear-gradient(180deg,#0a1330,#0a1330d9);border-bottom:1px solid var(--hair);backdrop-filter:blur(8px)}
.player-bar .pb-brand{display:flex;align-items:center;gap:.4rem;font-weight:800;font-size:.84rem;color:#cdd8f5}
.player-bar .pb-title{flex:1;min-width:0;font-family:'Space Grotesk',sans-serif;font-weight:700;font-size:.9rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;text-align:center;color:#dfe6ff}
.player-bar button,.player-bar #pb-open{display:inline-flex;align-items:center;gap:.35rem;padding:.34rem .72rem;border-radius:10px;cursor:pointer;
  border:1px solid var(--hair2);background:rgba(255,255,255,.05);color:var(--ink);font-weight:700;font-size:.8rem;font-family:inherit;text-decoration:none;
  transition:transform .14s,background .14s,border-color .14s}
.player-bar button:hover,.player-bar #pb-open:hover{transform:translateY(-1px);background:rgba(255,255,255,.12)}
.player-bar .pb-back{background:linear-gradient(135deg,#2f6bff,#4b8bff);border-color:transparent;color:#fff}
.player-stage{flex:1;position:relative;background:#000}
.player-stage iframe{position:absolute;inset:0;width:100%;height:100%;border:0;background:#fff}
.player-stage .loading{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:14px;color:#cfe;background:#05060f}
.spin{width:52px;height:52px;border-radius:50%;border:5px solid rgba(255,255,255,.15);border-top-color:var(--p2);animation:spin 1s linear infinite}
@media(max-width:600px){.player-bar .pb-brand span{display:none}.player-bar button .lbl{display:none}}

/* ---------- Animações ---------- */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes bob{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-4px) rotate(-6deg)}}
@keyframes twinkle{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pop{0%{opacity:0;transform:translateY(14px) scale(.96)}100%{opacity:1;transform:none}}
.card{animation:pop .4s ease backwards}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
}

/* ============================================================
   MODO GAMIFICADO (gami.js) — widget, auth, perfil, toasts
   ============================================================ */

/* Widget no topo */
#gami-slot{display:flex;align-items:center}
.gami-chip{display:flex;align-items:center;gap:.55rem;padding:.4rem .8rem .4rem .5rem;border-radius:999px;cursor:pointer;
  border:2px solid var(--hair2);background:rgba(255,255,255,.05);color:var(--ink);font-family:inherit;
  transition:transform .14s,border-color .14s,background .14s}
.gami-chip:hover{transform:translateY(-2px);border-color:var(--p1);background:rgba(255,255,255,.09)}
.gami-chip .gc-av{font-size:1.5rem;line-height:1;width:34px;height:34px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;background:linear-gradient(135deg,var(--p1),var(--p3))}
.gami-chip .gc-info{display:flex;flex-direction:column;line-height:1.1;text-align:left}
.gami-chip .gc-info b{font-size:.9rem;font-family:'Space Grotesk',sans-serif}
.gami-chip .gc-sub{font-size:.72rem;color:var(--muted);font-weight:700}
@media(max-width:560px){.gami-chip .gc-info{display:none}}

/* Modais (auth + perfil) */
.gami-modal{position:fixed;inset:0;z-index:95;display:none;align-items:center;justify-content:center;padding:18px;
  background:rgba(5,6,15,.78);backdrop-filter:blur(6px)}
.gami-modal.open{display:flex}
.gm-card{position:relative;width:100%;max-width:560px;max-height:92vh;overflow-y:auto;
  background:linear-gradient(165deg,var(--panel),var(--panel2));border:1px solid var(--hair2);
  border-radius:var(--radius);padding:26px;box-shadow:var(--shadow);animation:pop .3s ease}
.gm-x{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;cursor:pointer;
  border:2px solid var(--hair2);background:rgba(255,255,255,.05);color:var(--ink);font-size:1rem;font-family:inherit;
  display:flex;align-items:center;justify-content:center;transition:background .14s}
.gm-x:hover{background:rgba(255,255,255,.12)}
.gm-tabs{display:flex;gap:8px;margin-bottom:16px}
.gm-tab{flex:1;padding:.7rem;border-radius:14px;cursor:pointer;border:2px solid var(--hair2);
  background:rgba(255,255,255,.04);color:var(--muted);font-weight:800;font-family:inherit;font-size:.92rem;transition:.14s}
.gm-tab.on{background:linear-gradient(135deg,var(--p1),var(--p3));border-color:transparent;color:#fff}
.gm-lead{color:var(--muted);font-size:.95rem;margin-bottom:14px}
.gm-err{background:rgba(244,63,94,.16);border:1px solid rgba(244,63,94,.5);color:#fecdd3;
  padding:.7rem 1rem;border-radius:12px;font-size:.9rem;margin-bottom:12px}
.gm-label{display:block;font-weight:800;font-size:.85rem;margin-bottom:8px;color:var(--ink)}
.gm-sep{margin:16px 0 10px;font-weight:800;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;color:var(--p2);
  border-top:1px solid var(--hair);padding-top:14px}
.gm-row{display:flex;gap:10px;flex-wrap:wrap}
.gm-field{display:flex;flex-direction:column;gap:.3rem;font-size:.82rem;font-weight:700;color:var(--muted);flex:1;min-width:130px;margin-bottom:10px}
.gm-field.gm-uf{flex:0 0 64px;min-width:64px}
.gm-field input{padding:.7rem .8rem;border-radius:12px;border:2px solid var(--hair2);background:rgba(255,255,255,.05);
  color:var(--ink);font-size:1rem;font-family:inherit;transition:border-color .14s}
.gm-field input:focus{outline:none;border-color:var(--p1)}
.gm-check{display:flex;gap:.6rem;align-items:flex-start;font-size:.86rem;color:var(--muted);margin:6px 0 16px;cursor:pointer;line-height:1.4}
.gm-check input{margin-top:.2rem;width:18px;height:18px;flex-shrink:0;accent-color:var(--p1)}
.gm-submit{width:100%;margin-top:4px}

/* Avatar picker */
.av-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:16px}
@media(max-width:440px){.av-grid{grid-template-columns:repeat(4,1fr)}}
.av-opt{font-size:1.7rem;aspect-ratio:1;border-radius:14px;cursor:pointer;border:2px solid var(--hair2);
  background:rgba(255,255,255,.04);display:flex;align-items:center;justify-content:center;transition:.14s}
.av-opt:hover{transform:translateY(-2px);background:rgba(255,255,255,.09)}
.av-opt.on{border-color:transparent;background:linear-gradient(135deg,var(--p1),var(--p3));transform:scale(1.06)}

/* Perfil */
.gm-prof .prof-head{display:flex;align-items:center;gap:14px;margin-bottom:16px}
.prof-av{font-size:2.6rem;width:68px;height:68px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--p1),var(--p3));flex-shrink:0}
.prof-head h2{font-size:1.5rem}
.prof-lv{font-size:.85rem;color:var(--p2);font-weight:800}
.prof-stats{display:flex;gap:10px;margin-bottom:14px}
.prof-stats .ps{flex:1;text-align:center;background:rgba(255,255,255,.04);border:1px solid var(--hair);border-radius:14px;padding:12px 6px}
.prof-stats .ps b{display:block;font-family:'Space Grotesk',sans-serif;font-size:1.3rem}
.prof-stats .ps span{font-size:.74rem;color:var(--muted);font-weight:700}
.xpbar{height:14px;border-radius:999px;background:rgba(255,255,255,.08);overflow:hidden;border:1px solid var(--hair)}
.xpbar i{display:block;height:100%;background:linear-gradient(90deg,var(--p1),var(--p2));border-radius:999px;transition:width .5s ease}
.xpbar-lbl{font-size:.8rem;color:var(--muted);text-align:center;margin-top:6px;font-weight:700}
.prof-h3{font-size:1rem;margin:18px 0 10px}
.ach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
@media(max-width:440px){.ach-grid{grid-template-columns:repeat(2,1fr)}}
.ach{display:flex;flex-direction:column;align-items:center;gap:.3rem;text-align:center;padding:12px 6px;border-radius:14px;
  border:1px solid var(--hair);background:rgba(255,255,255,.03);opacity:.4;filter:grayscale(1);transition:.18s}
.ach.on{opacity:1;filter:none;border-color:var(--yellow);background:linear-gradient(160deg,rgba(251,191,36,.14),rgba(47,107,255,.1))}
.ach-em{font-size:1.8rem}
.ach-lb{font-size:.72rem;font-weight:700;line-height:1.15;color:var(--ink)}
.lb{display:flex;flex-direction:column;gap:6px}
.lb-row{display:flex;align-items:center;gap:10px;padding:.5rem .7rem;border-radius:12px;background:rgba(255,255,255,.03);border:1px solid var(--hair)}
.lb-row.me{border-color:var(--p2);background:linear-gradient(135deg,rgba(34,211,238,.14),rgba(47,107,255,.1))}
.lb-rank{font-weight:800;font-family:'Space Grotesk',sans-serif;width:34px;color:var(--p2)}
.lb-av{font-size:1.3rem}
.lb-nick{flex:1;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lb-xp{font-weight:800;font-size:.85rem;color:var(--muted)}

/* Botão Concluí no player */
.player-bar .pb-done{background:linear-gradient(135deg,var(--green),#22d3ee);border-color:transparent;color:#04220f}

/* Toasts */
#gami-toasts{position:fixed;top:80px;right:18px;z-index:120;display:flex;flex-direction:column;gap:10px;max-width:320px}
@media(max-width:560px){#gami-toasts{left:18px;right:18px;max-width:none}}
.gami-toast{background:linear-gradient(160deg,var(--panel),var(--panel2));border:1px solid var(--hair2);
  border-radius:16px;padding:14px 16px;font-size:.92rem;box-shadow:var(--shadow);animation:slidein .35s ease;border-left:5px solid var(--p2)}
.gami-toast.xp{border-left-color:var(--yellow)}
.gami-toast.level{border-left-color:var(--p1)}
.gami-toast.ach{border-left-color:var(--green)}
.gami-toast.out{animation:slideout .4s ease forwards}
@keyframes slidein{from{opacity:0;transform:translateX(40px)}to{opacity:1;transform:none}}
@keyframes slideout{to{opacity:0;transform:translateX(40px)}}

/* ---------- Marca oficial: logo no topo + mascote no hero ---------- */
.brand .logo-img{height:46px;width:auto;filter:drop-shadow(0 4px 12px rgba(47,107,255,.4));transition:transform .2s ease}
.brand:hover .logo-img{transform:scale(1.05) rotate(-2deg)}
@media(max-width:600px){.brand .bt{display:none}}
.hero-mascote{width:clamp(230px,34vw,390px);height:auto;position:relative;z-index:2;
  filter:drop-shadow(0 30px 46px rgba(47,107,255,.5));animation:float 5s ease-in-out infinite}

/* ---------- Mascote comemorando (XP / conquista / nível) ---------- */
.celebrate{position:fixed;inset:0;z-index:130;display:none;flex-direction:column;align-items:center;justify-content:center;gap:2px;pointer-events:none}
.celebrate.show{display:flex}
.confetti{position:absolute;inset:0;overflow:hidden;pointer-events:none}
.confetti i{position:absolute;top:-24px;width:11px;height:15px;border-radius:2px;opacity:.95;animation:cel-fall linear forwards}
.celebrate-card{position:relative;z-index:2;text-align:center;background:linear-gradient(160deg,var(--panel),var(--panel2));
  border:2px solid var(--yellow);border-radius:22px;padding:14px 26px;box-shadow:var(--shadow);animation:cel-card .5s ease both}
.cc-em{font-size:2.6rem;line-height:1}
.cc-title{font-family:'Space Grotesk',sans-serif;font-weight:800;font-size:1.25rem;color:#fff;margin-top:2px}
.cc-sub{color:var(--yellow);font-weight:800;font-size:.95rem}
.celebrate-bot{width:clamp(170px,38vw,250px);height:auto;position:relative;z-index:2;margin-top:-4px;
  filter:drop-shadow(0 18px 36px rgba(47,107,255,.6));
  animation:cel-pop .6s cubic-bezier(.2,1.5,.4,1) both, cel-jump 1.1s ease-in-out .6s 2}
@keyframes cel-pop{0%{opacity:0;transform:translateY(70px) scale(.3) rotate(-14deg)}60%{opacity:1;transform:translateY(-10px) scale(1.08) rotate(5deg)}100%{opacity:1;transform:none}}
@keyframes cel-jump{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-22px) rotate(3deg)}}
@keyframes cel-card{from{opacity:0;transform:translateY(24px) scale(.9)}to{opacity:1;transform:none}}
@keyframes cel-fall{to{transform:translateY(112vh) rotate(680deg);opacity:.3}}

/* Link para a plataforma EJR Hub no cabeçalho */
.hub-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.9rem;font-weight:700;color:var(--muted);
  padding:.4rem .8rem;border-radius:999px;border:1px solid var(--hair2);background:rgba(255,255,255,.04);transition:.15s}
.hub-link:hover{color:var(--ink);background:rgba(34,211,238,.12);border-color:var(--p2);transform:translateY(-1px)}
.hub-link svg{transition:transform .15s}
.hub-link:hover svg{transform:translateX(-2px)}
@media(max-width:440px){.hub-link .hub-lbl{display:none}}

/* ---------- Cadastro: selects de estado/cidade + feedback de apelido ---------- */
.gm-field select{padding:.7rem .8rem;border-radius:12px;border:2px solid var(--hair2);background:rgba(255,255,255,.05);
  color:var(--ink);font-size:1rem;font-family:inherit;cursor:pointer;transition:border-color .14s;
  appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23a9b6da' d='M6 8 0 0h12z'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right .9rem center;padding-right:2rem}
.gm-field select:focus{outline:none;border-color:var(--p1)}
.gm-field select:disabled{opacity:.55;cursor:not-allowed}
.gm-field select option{background:#122046;color:var(--ink)}
.gm-field.gm-age{flex:0 0 76px;min-width:76px}
.gm-field input.ok{border-color:var(--green)}
.gm-field input.bad{border-color:#f87171}
.nick-hint{font-size:.74rem;font-weight:700;margin-top:2px;min-height:.9rem;color:var(--muted)}
.nick-hint.ok{color:var(--green)}
.nick-hint.bad{color:#f87171}
.nick-hint.checking{color:var(--muted);opacity:.8}
