/* ===================================================
   Jogago — portal de jogos
   Estilo inspirado em Poki/CrazyGames, identidade própria
   Layout: topbar + sidebar fixa + grade densa de cards
   =================================================== */
:root{
  --bg:#11132b;          /* fundo azul-noite profundo */
  --bg-soft:#1a1d3d;
  --panel:#21254a;
  --panel-2:#2a2f57;
  --line:#343a6b;
  --txt:#f4f5ff;
  --dim:#9aa0d4;
  --brand:#ff3d77;       /* rosa vibrante (marca) */
  --brand-2:#ffd23f;     /* amarelo moeda */
  --accent:#3ddc97;      /* verde sucesso */
  --radius:18px;
  --side-w:230px;
  --top-h:64px;
  --font-d:'Fredoka',sans-serif;
  --font-b:'Nunito',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  background-image:
    radial-gradient(1200px 600px at 100% -5%, rgba(255,61,119,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(61,220,151,.08), transparent 55%);
  color:var(--txt); font-family:var(--font-b); min-height:100vh;
}
a{text-decoration:none;color:inherit}

/* ---------- Topbar ---------- */
.topbar{
  position:fixed; top:0; left:0; right:0; height:var(--top-h); z-index:100;
  display:flex; align-items:center; gap:1rem; padding:0 1.4rem;
  background:rgba(17,19,43,.9); backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.menu-toggle{display:none;background:none;border:none;color:var(--txt);font-size:1.5rem;cursor:pointer}
.logo{font-family:var(--font-d);font-weight:700;font-size:1.5rem;display:flex;align-items:center;gap:.1rem;letter-spacing:-.5px}
.logo-mark{
  display:inline-grid;place-items:center;width:34px;height:34px;margin-right:.5rem;
  background:var(--brand);color:#fff;border-radius:10px;font-size:1.2rem;
  transform:rotate(-8deg); box-shadow:0 4px 0 #c41e54;
}
.logo-go{color:var(--brand)}

.search{position:relative;flex:1;max-width:480px;margin:0 auto}
.search input{
  width:100%;height:42px;padding:0 2.6rem 0 1.1rem;border-radius:999px;
  background:var(--panel);border:2px solid transparent;color:var(--txt);
  font-family:var(--font-b);font-size:.95rem;transition:.18s;
}
.search input::placeholder{color:var(--dim)}
.search input:focus{outline:none;border-color:var(--brand);background:var(--bg-soft)}
.search-icon{position:absolute;right:1rem;top:50%;transform:translateY(-50%);opacity:.7;font-size:.95rem}

.top-actions{display:flex;align-items:center;gap:.7rem}
.coin{
  display:flex;align-items:center;gap:.4rem;background:var(--panel);
  padding:.4rem .9rem;border-radius:999px;font-weight:800;color:var(--brand-2);
  font-family:var(--font-d);border:1px solid var(--line);
}
.avatar{
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--brand),#ff7eb3);color:#fff;
  font-family:var(--font-d);font-weight:700;font-size:1.1rem;
}
.btn,.btn-ghost{
  font-family:var(--font-d);font-weight:600;font-size:.9rem;padding:.5rem 1.1rem;
  border-radius:999px;cursor:pointer;transition:.15s;white-space:nowrap;
}
.btn{background:var(--brand);color:#fff;border:none;box-shadow:0 4px 0 #c41e54}
.btn:hover{transform:translateY(-2px);box-shadow:0 6px 0 #c41e54}
.btn:active{transform:translateY(2px);box-shadow:0 2px 0 #c41e54}
.btn-ghost{border:2px solid var(--line);color:var(--txt);background:transparent}
.btn-ghost:hover{border-color:var(--brand)}

/* ---------- Layout sidebar + conteúdo ---------- */
.layout{display:flex;padding-top:var(--top-h)}
.sidebar{
  position:fixed;top:var(--top-h);bottom:0;left:0;width:var(--side-w);
  padding:1.2rem .8rem;overflow-y:auto;border-right:1px solid var(--line);
  background:rgba(26,29,61,.5);
}
.sidebar nav{display:flex;flex-direction:column;gap:.3rem}
.side-link{
  display:flex;align-items:center;gap:.8rem;padding:.7rem .9rem;border-radius:12px;
  color:var(--dim);font-weight:700;font-size:.92rem;transition:.15s;
}
.side-link:hover{background:var(--panel);color:var(--txt)}
.side-link.ativo{background:var(--brand);color:#fff;box-shadow:0 4px 0 #c41e54}
.side-ic{font-size:1.2rem;width:24px;text-align:center}
.side-sep{height:1px;background:var(--line);margin:.7rem .5rem}

.content{margin-left:var(--side-w);flex:1;padding:1.6rem 2rem 4rem;max-width:1400px}
.sidebar-backdrop{display:none}

/* ---------- Destaques ---------- */
.featured{
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:1rem;margin-bottom:2rem;
}
.feat-card{
  position:relative;border-radius:var(--radius);padding:1.4rem;min-height:170px;
  display:flex;align-items:flex-end;overflow:hidden;
  background:linear-gradient(140deg,var(--c),color-mix(in srgb,var(--c) 55%,#000));
  box-shadow:0 10px 30px rgba(0,0,0,.3);transition:.2s;
}
.feat-card:hover{transform:translateY(-4px) scale(1.01)}
.feat-emoji{position:absolute;top:-10px;right:-6px;font-size:6rem;opacity:.35;transform:rotate(12deg)}
.feat-big .feat-emoji{font-size:9rem}
.feat-body{position:relative;z-index:1}
.feat-tag{
  display:inline-block;background:rgba(255,255,255,.25);color:#fff;font-weight:800;
  font-size:.65rem;text-transform:uppercase;letter-spacing:.5px;padding:.25rem .6rem;border-radius:999px;
}
.feat-card h2{font-family:var(--font-d);font-weight:700;color:#fff;font-size:1.5rem;margin-top:.5rem;text-shadow:0 2px 8px rgba(0,0,0,.3)}
.feat-big h2{font-size:2.2rem}
.feat-card p{color:rgba(255,255,255,.9);font-size:.9rem;margin-top:.3rem;max-width:80%}

/* ---------- Cabeçalho de seção ---------- */
.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.2rem}
.section-head h1{font-family:var(--font-d);font-weight:700;font-size:1.6rem}
.count{color:var(--dim);font-weight:700;font-size:.9rem}

/* ---------- Grade de jogos ---------- */
.grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1.1rem;
}
.game-card{
  border-radius:var(--radius);overflow:hidden;background:var(--panel);
  border:1px solid var(--line);transition:.18s;
  opacity:0;transform:translateY(12px);animation:rise .45s ease forwards;animation-delay:var(--d,0s);
}
@keyframes rise{to{opacity:1;transform:translateY(0)}}
.game-card:hover{transform:translateY(-6px);border-color:var(--c);box-shadow:0 12px 28px rgba(0,0,0,.35)}
.card-thumb{
  aspect-ratio:1;display:grid;place-items:center;font-size:3.4rem;position:relative;
  background-color:var(--c);background-size:cover;background-position:center;
  background-image:linear-gradient(140deg,var(--c),color-mix(in srgb,var(--c) 50%,#000));
}
.card-thumb::after{
  content:"";position:absolute;inset:0;
  background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.25),transparent 50%);
}
.card-thumb span{position:relative;z-index:1;filter:drop-shadow(0 4px 8px rgba(0,0,0,.3));transition:.2s}
.game-card:hover .card-thumb span{transform:scale(1.15) rotate(-6deg)}
.card-foot{padding:.7rem .8rem}
.card-foot h3{font-family:var(--font-d);font-weight:600;font-size:1rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card-meta{display:flex;gap:.8rem;color:var(--dim);font-size:.78rem;font-weight:700;margin-top:.3rem}

/* ---------- Formulários (login/cadastro) ---------- */
.card-form{
  max-width:400px;margin:2rem auto;background:var(--panel);
  border:1px solid var(--line);border-radius:var(--radius);padding:2.2rem;
}
.card-form h1{font-family:var(--font-d);font-weight:700;margin-bottom:1.4rem;text-align:center}
.card-form label{display:block;font-size:.82rem;color:var(--dim);font-weight:700;margin-bottom:1rem}
.card-form input{
  width:100%;margin-top:.35rem;height:46px;padding:0 1rem;border-radius:12px;
  border:2px solid var(--line);background:var(--bg-soft);color:var(--txt);
  font-family:var(--font-b);font-size:.95rem;transition:.15s;
}
.card-form input:focus{outline:none;border-color:var(--brand)}
.card-form .btn{width:100%;height:48px;margin-top:.5rem;font-size:1rem}
.card-form .sub{text-align:center;color:var(--dim);font-size:.85rem;margin-top:1.2rem}
.card-form .sub a{color:var(--brand);font-weight:800}
.erro{background:rgba(255,61,119,.14);border:1px solid var(--brand);color:#ffb3c9;
  padding:.8rem;border-radius:12px;font-size:.88rem;margin-bottom:1.2rem;font-weight:700}

/* ---------- Página do jogo ---------- */
.play-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.4rem;flex-wrap:wrap;gap:1rem}
.play-head h1{font-family:var(--font-d);font-weight:700;font-size:1.8rem}
.like-btn{
  display:flex;align-items:center;gap:.5rem;background:var(--panel);
  border:2px solid var(--line);color:var(--dim);padding:.6rem 1.3rem;
  border-radius:999px;cursor:pointer;font-family:var(--font-d);font-weight:600;font-size:1rem;transition:.15s;
}
.like-btn:hover{border-color:var(--brand)}
.like-btn.ativo{color:#fff;border-color:var(--brand);background:var(--brand);box-shadow:0 4px 0 #c41e54}
#game-area{
  background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:3.5rem 2rem;text-align:center;min-height:360px;display:grid;place-content:center;gap:1.4rem;
}
.game-score{font-size:1.2rem;color:var(--dim);font-weight:700}
#cliques{color:var(--accent);font-family:var(--font-d);font-weight:700;font-size:1.8rem}
.big-click{
  font-family:var(--font-d);font-size:1.6rem;font-weight:700;padding:1.6rem 3.2rem;border:none;
  border-radius:20px;background:var(--brand);color:#fff;cursor:pointer;box-shadow:0 6px 0 #c41e54;transition:.1s;
}
.big-click:hover{transform:translateY(-2px);box-shadow:0 8px 0 #c41e54}
.big-click:active{transform:translateY(4px);box-shadow:0 2px 0 #c41e54}
.hint{color:var(--dim);font-size:.85rem}

/* Toast de pontos */
#toast{
  position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(20px) scale(.9);
  background:var(--brand-2);color:#3a2c00;font-family:var(--font-d);font-weight:700;
  padding:.7rem 1.5rem;border-radius:999px;opacity:0;transition:.3s cubic-bezier(.2,1.4,.5,1);
  pointer-events:none;box-shadow:0 8px 24px rgba(255,210,63,.4);z-index:200;
}
#toast.show{opacity:1;transform:translateX(-50%) translateY(0) scale(1)}

/* ---------- Ranking ---------- */
.page-title{font-family:var(--font-d);font-weight:700;font-size:1.8rem;margin-bottom:1.4rem}
.ranking{width:100%;border-collapse:separate;border-spacing:0 .5rem}
.ranking th{color:var(--dim);font-size:.75rem;text-transform:uppercase;text-align:left;padding:0 1.2rem;letter-spacing:.5px}
.ranking td{background:var(--panel);padding:1rem 1.2rem;font-weight:700}
.ranking td:first-child{border-radius:12px 0 0 12px;color:var(--dim)}
.ranking td:last-child{border-radius:0 12px 12px 0;color:var(--brand-2);font-family:var(--font-d);text-align:right}
.ranking tr.top td{background:var(--panel-2)}
.ranking tr.top td:first-child{color:var(--brand-2);font-family:var(--font-d);font-size:1.1rem}

/* ---------- Responsivo ---------- */
@media (max-width:900px){
  .featured{grid-template-columns:1fr 1fr}
  .feat-big{grid-column:span 2}
}
@media (max-width:720px){
  .menu-toggle{display:block}
  .sidebar{transform:translateX(-100%);transition:.25s;z-index:90}
  body.sidebar-open .sidebar{transform:translateX(0)}
  body.sidebar-open .sidebar-backdrop{display:block;position:fixed;inset:var(--top-h) 0 0 0;background:rgba(0,0,0,.5);z-index:80}
  .content{margin-left:0}
  .featured{grid-template-columns:1fr}
  .feat-big{grid-column:auto}
  .search{margin:0}
  .logo span:not(.logo-mark):not(.logo-go){display:none}
}

/* ---------- Comentários: form e estrelas (compartilhado) ---------- */
.com-form{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--radius);padding:1.2rem;display:flex;flex-direction:column;gap:.8rem;margin-bottom:1.4rem}
.com-form textarea{width:100%;padding:.8rem;border-radius:12px;border:2px solid var(--line);background:var(--bg);color:var(--txt);font-family:var(--font-b);font-size:.95rem;resize:vertical}
.com-form textarea:focus{outline:none;border-color:var(--brand)}
.com-form .btn{align-self:flex-start}
.rate{display:flex;gap:.2rem;font-size:1.6rem;color:var(--brand-2);cursor:pointer;user-select:none}
.rate span{transition:.1s}.rate span:hover{transform:scale(1.2)}
.flash-ok{background:rgba(61,220,151,.14);border:1px solid var(--accent);color:#9ff0cb;padding:.7rem 1rem;border-radius:12px;font-weight:700;margin-bottom:1rem}
.com-meta{display:flex;align-items:center;gap:.7rem;margin-bottom:.4rem;font-size:.88rem}
.com-meta .stars{color:var(--brand-2)}
.com-meta .dim{color:var(--dim);font-weight:400;font-size:.8rem}
.com-content p{font-size:.92rem;line-height:1.5;color:#dfe2ff}
.dim{color:var(--dim)}

/* ---------- Aviso global ---------- */
.global-notice{padding:.7rem 1.4rem;text-align:center;font-weight:700;font-size:.9rem;position:relative;z-index:101}
.global-notice.n-info{background:#3D9BFF;color:#04223f}
.global-notice.n-alerta{background:var(--brand-2);color:#3a2c00}
.global-notice.n-sucesso{background:var(--accent);color:#04221a}

/* ---------- Sininho de notificações ---------- */
.bell{position:relative;cursor:pointer;font-size:1.3rem;padding:.3rem;user-select:none}
.bell-badge{position:absolute;top:-2px;right:-4px;background:var(--brand);color:#fff;font-family:var(--font-d);font-size:.6rem;font-weight:700;min-width:16px;height:16px;border-radius:999px;display:grid;place-items:center;padding:0 3px}
.notif-drop{position:absolute;top:140%;right:0;width:300px;max-height:380px;overflow-y:auto;background:var(--panel);border:1px solid var(--line);border-radius:14px;box-shadow:0 16px 40px rgba(0,0,0,.45);opacity:0;visibility:hidden;transform:translateY(-8px);transition:.18s;z-index:120}
.notif-drop.open{opacity:1;visibility:visible;transform:translateY(0)}
.notif-head{font-family:var(--font-d);font-weight:600;padding:.9rem 1rem;border-bottom:1px solid var(--line)}
.notif-item{display:block;padding:.8rem 1rem;border-bottom:1px solid var(--line);font-size:.85rem;transition:.12s}
.notif-item:hover{background:var(--panel-2,#2a2f57)}
.notif-item.nao-lida{background:rgba(255,61,119,.08);border-left:3px solid var(--brand)}
.notif-item b{display:block;font-weight:700}
.notif-item span{display:block;color:var(--dim);margin:.2rem 0}
.notif-item small{color:var(--dim);font-size:.72rem}
.notif-vazio,.notif-loading{padding:1.5rem 1rem;text-align:center;color:var(--dim);font-size:.85rem}

/* ---------- Blocos de anúncio ---------- */
.ad-wrap{display:flex;justify-content:center;padding:1rem 2rem;max-width:1400px;margin:0 auto}
.ad-wrap.side{padding:1rem 0 0;margin-top:1rem;border-top:1px solid var(--line)}
.ad-slot{max-width:100%;overflow:hidden}

/* ---------- Links no rodapé ---------- */
.footer-links{display:flex;gap:1.4rem;justify-content:center;flex-wrap:wrap;margin-bottom:.8rem}
.footer-links a{color:var(--dim);font-size:.85rem;font-weight:700}
.footer-links a:hover{color:var(--brand)}

/* ---------- Páginas estáticas ---------- */
.pagina-estatica{max-width:720px}
.pagina-estatica h1{font-family:var(--font-d);font-weight:700;font-size:1.8rem;margin-bottom:1.2rem}
.pagina-estatica .conteudo{color:#dfe2ff;line-height:1.7;font-size:1rem}
.pagina-estatica a{color:var(--brand);font-weight:700}

/* ---------- Botões de favoritar / ações do jogo ---------- */
.play-actions{display:flex;gap:.6rem;flex-wrap:wrap}
.fav-btn{display:flex;align-items:center;gap:.4rem;background:var(--panel);border:2px solid var(--line);color:var(--dim);padding:.6rem 1.1rem;border-radius:999px;cursor:pointer;font-family:var(--font-d);font-weight:600;font-size:.9rem;transition:.15s}
.fav-btn:hover{border-color:var(--brand-2)}
.fav-btn.ativo{color:#3a2c00;background:var(--brand-2);border-color:var(--brand-2)}
.fav-ic{font-size:1.1rem}

/* ---------- Trilhos (recentes/favoritos) ---------- */
.rail{margin-bottom:2rem}
.rail h2{font-family:var(--font-d);font-weight:600;font-size:1.2rem;margin-bottom:.9rem}

/* ---------- Carregar mais ---------- */
.load-more{text-align:center;padding:2rem 0}
.load-more button{font-family:var(--font-d);font-weight:600;background:var(--panel);border:2px solid var(--line);color:var(--txt);padding:.8rem 2rem;border-radius:999px;cursor:pointer;transition:.15s}
.load-more button:hover{border-color:var(--brand);transform:translateY(-2px)}

/* ---------- Selo de usuário ---------- */
.user-badge{background:var(--brand-2);color:#3a2c00;font-family:var(--font-d);font-weight:700;font-size:.65rem;padding:.15rem .5rem;border-radius:999px}

/* ---------- Loja ---------- */
.shop-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}
.shop-head h1{font-family:var(--font-d);font-weight:700;font-size:1.8rem}
.saldo{background:var(--panel);border:1px solid var(--line);padding:.6rem 1.2rem;border-radius:999px;font-weight:700}
.saldo b{color:var(--brand-2);font-family:var(--font-d)}
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:1.2rem;margin-bottom:2.5rem}
.shop-item{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem;text-align:center;transition:.18s;position:relative}
.shop-item:hover{transform:translateY(-4px);border-color:var(--c)}
.shop-item.equipado{border-color:var(--c);box-shadow:0 0 0 2px var(--c) inset}
.shop-icon{font-size:3rem;margin-bottom:.6rem;filter:drop-shadow(0 4px 10px rgba(0,0,0,.3))}
.shop-item h3{font-family:var(--font-d);font-weight:600;font-size:1.05rem}
.shop-item p{color:var(--dim);font-size:.82rem;margin:.4rem 0 .8rem;min-height:2.2em}
.shop-price{font-family:var(--font-d);font-weight:700;color:var(--brand-2);font-size:1.2rem;margin-bottom:.9rem}
.shop-item .btn,.shop-item .btn-ghost{width:100%}
.meus-itens h2{font-family:var(--font-d);font-weight:600;font-size:1.3rem;margin-bottom:1rem}
.flash-ok{background:rgba(61,220,151,.14);border:1px solid var(--accent);color:#9ff0cb;padding:.8rem 1rem;border-radius:12px;font-weight:700;margin-bottom:1.2rem}
.flash-erro{background:rgba(255,61,119,.14);border:1px solid var(--brand);color:#ffb3c9;padding:.8rem 1rem;border-radius:12px;font-weight:700;margin-bottom:1.2rem}

/* ---------- Streak pill ---------- */
.streak-pill{background:linear-gradient(135deg,#ff6b35,#ff3d77);color:#fff;font-family:var(--font-d);font-weight:700;font-size:.8rem;padding:.3rem .7rem;border-radius:999px}

/* ---------- Perfil ---------- */
.profile-head{display:flex;align-items:center;gap:1.5rem;margin-bottom:1.5rem;flex-wrap:wrap}
.profile-avatar{width:90px;height:90px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-d);font-weight:700;font-size:2.6rem;background:linear-gradient(135deg,var(--brand),#ff7eb3);color:#fff;flex-shrink:0}
.profile-info h1{font-family:var(--font-d);font-weight:700;font-size:1.9rem;display:flex;align-items:center;gap:.6rem}
.profile-bio{color:#dfe2ff;margin:.5rem 0;line-height:1.5}
.profile-since{color:var(--dim);font-size:.85rem}
.edit-bio{margin-bottom:1.5rem;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:1rem 1.2rem}
.edit-bio summary{cursor:pointer;font-weight:700;color:var(--dim)}
.edit-bio textarea{width:100%;margin:.8rem 0;padding:.7rem;border-radius:10px;border:2px solid var(--line);background:var(--bg-soft);color:var(--txt);font-family:var(--font-b);resize:vertical}
.edit-bio textarea:focus{outline:none;border-color:var(--brand)}

.profile-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-bottom:2.5rem}
.pstat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1.2rem;text-align:center}
.pstat b{display:block;font-family:var(--font-d);font-size:1.5rem;color:var(--txt)}
.pstat small{color:var(--dim);font-weight:700;font-size:.78rem}

/* ---------- Conquistas ---------- */
.achievements{margin-bottom:2.5rem}
.achievements h2{font-family:var(--font-d);font-weight:600;font-size:1.3rem;margin-bottom:1rem}
.ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1rem}
.ach{display:flex;align-items:center;gap:1rem;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:1rem;position:relative;transition:.15s}
.ach.obtida{border-color:var(--brand-2);background:linear-gradient(135deg,rgba(255,210,63,.08),var(--panel))}
.ach.bloqueada{opacity:.6}
.ach-icon{font-size:2.2rem;flex-shrink:0;filter:grayscale(0)}
.ach.bloqueada .ach-icon{filter:grayscale(1)}
.ach-body{flex:1;min-width:0}
.ach-body b{display:block;font-family:var(--font-d);font-weight:600}
.ach-body span{color:var(--dim);font-size:.8rem}
.ach-data{color:var(--brand-2);font-weight:700;font-size:.75rem}
.ach-bar{height:6px;background:var(--bg);border-radius:999px;margin-top:.4rem;overflow:hidden}
.ach-bar div{height:100%;background:var(--brand);border-radius:999px;transition:.3s}
.ach-reward{position:absolute;top:.6rem;right:.8rem;color:var(--brand-2);font-family:var(--font-d);font-weight:700;font-size:.8rem}

.rank-name{color:inherit;font-weight:700}
.rank-name:hover{color:var(--brand)}

/* ---------- Toast de conquista ---------- */
.ach-toast{position:fixed;bottom:80px;left:50%;transform:translateX(-50%) translateY(30px);background:linear-gradient(135deg,#ffd23f,#ff9a3f);color:#3a2c00;font-family:var(--font-d);font-weight:700;padding:.9rem 1.6rem;border-radius:999px;box-shadow:0 10px 30px rgba(255,154,63,.5);opacity:0;transition:.4s cubic-bezier(.2,1.4,.5,1);z-index:300;display:flex;align-items:center;gap:.5rem}
.ach-toast span{font-size:1.4rem}
.ach-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ===================================================
   PÁGINA DE JOGO — layout profissional (v2)
   =================================================== */

/* Breadcrumb */
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.82rem;color:var(--dim);margin-bottom:1rem;flex-wrap:wrap}
.breadcrumb a{color:var(--dim);font-weight:700}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb span{color:var(--txt)}

/* Layout principal: jogo + sidebar */
.play-layout{display:grid;grid-template-columns:1fr 300px;gap:1.5rem;margin-bottom:2.5rem}
.play-main{min-width:0}

/* Palco do jogo */
.game-stage{position:relative;width:100%;aspect-ratio:16/9;border-radius:var(--radius) var(--radius) 0 0;overflow:hidden;background:#000;box-shadow:0 12px 40px rgba(0,0,0,.4)}
.game-stage iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.game-stage:fullscreen{border-radius:0}
#game-area{position:absolute;inset:0;display:grid;place-content:center;gap:1.4rem;text-align:center;background:var(--panel)}

/* Barra de ações integrada (abaixo do jogo) */
.game-bar{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--panel);border:1px solid var(--line);border-top:none;border-radius:0 0 var(--radius) var(--radius);padding:1rem 1.2rem;flex-wrap:wrap}
.game-bar-left{display:flex;align-items:center;gap:.9rem;min-width:0}
.game-bar-icon{width:54px;height:54px;border-radius:12px;background-size:cover;background-position:center;display:grid;place-items:center;font-size:1.8rem;flex-shrink:0}
.game-bar-meta{min-width:0}
.game-bar-meta h1{font-family:var(--font-d);font-weight:700;font-size:1.3rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.game-bar-stats{display:flex;align-items:center;gap:.8rem;margin-top:.2rem;font-size:.82rem;flex-wrap:wrap}
.rating-badge{background:rgba(255,210,63,.15);color:var(--brand-2);font-weight:700;padding:.15rem .5rem;border-radius:6px}
.rating-badge small{opacity:.7}
.game-bar-actions{display:flex;gap:.5rem;flex-shrink:0}
.ico-btn{display:flex;align-items:center;gap:.35rem;background:var(--bg-soft);border:2px solid var(--line);color:var(--dim);padding:.55rem .9rem;border-radius:10px;cursor:pointer;font-family:var(--font-d);font-weight:600;font-size:1rem;transition:.15s}
.ico-btn:hover{border-color:var(--brand);color:var(--txt)}
.ico-btn.like-btn.ativo{background:var(--brand);border-color:var(--brand);color:#fff}
.ico-btn.fav-btn.ativo{background:var(--brand-2);border-color:var(--brand-2);color:#3a2c00}

/* Sobre o jogo */
.game-about{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem;margin-top:1.5rem}
.game-about h2{font-family:var(--font-d);font-weight:600;font-size:1.15rem;margin-bottom:.6rem}
.game-about p{color:#cdd2f0;line-height:1.6;font-size:.92rem}

/* Sidebar recomendados */
.play-side{min-width:0}
.rec-box{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.1rem;position:sticky;top:80px}
.rec-box h3{font-family:var(--font-d);font-weight:600;font-size:1.05rem;margin-bottom:.9rem}
.rec-list{display:flex;flex-direction:column;gap:.6rem}
.rec-item{display:flex;align-items:center;gap:.7rem;padding:.4rem;border-radius:10px;transition:.15s}
.rec-item:hover{background:var(--bg-soft)}
.rec-thumb{width:56px;height:56px;border-radius:10px;background-size:cover;background-position:center;display:grid;place-items:center;font-size:1.6rem;flex-shrink:0}
.rec-info{min-width:0}
.rec-info b{display:block;font-size:.88rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-info small{color:var(--dim);font-size:.75rem}

/* Comentários (v2) */
.comments{margin-top:1.5rem;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:1.5rem}
.comments h2{font-family:var(--font-d);font-weight:600;font-size:1.2rem;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}
.count-badge{background:var(--brand);color:#fff;font-size:.7rem;font-weight:700;padding:.1rem .5rem;border-radius:999px}
.com-item{display:flex;gap:.8rem;padding:.9rem 0;border-bottom:1px solid var(--line)}
.com-item:last-child{border-bottom:none}
.com-avatar{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#ff7eb3);color:#fff;display:grid;place-items:center;font-family:var(--font-d);font-weight:700;flex-shrink:0}
.com-content{flex:1;min-width:0}

/* Mais jogos */
.more-games{margin-bottom:2rem}
.more-games h2{font-family:var(--font-d);font-weight:600;font-size:1.3rem;margin-bottom:1rem}

/* Responsivo: sidebar vai pra baixo */
@media (max-width:900px){
  .play-layout{grid-template-columns:1fr}
  .rec-box{position:static}
  .rec-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}
}
@media (max-width:600px){
  .game-bar{flex-direction:column;align-items:stretch}
  .game-bar-actions{justify-content:center}
}
