/* FPSTrain Arena — shared styles for /games/* trainers, hub + homepage game grid
   Matches site tokens: bg #06060e, accent #00e5ff, Outfit/Inter/JetBrains Mono */

/* ---------- game shell ---------- */
.ag-shell{max-width:1100px;margin:0 auto;border:1px solid rgba(0,229,255,.18);border-radius:16px;overflow:hidden;background:#0a0a16;box-shadow:0 0 60px rgba(0,229,255,.07),0 24px 60px rgba(0,0,0,.5)}
.ag-topbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 16px;background:rgba(17,17,40,.85);border-bottom:1px solid rgba(0,229,255,.12);flex-wrap:wrap}
.ag-stats{display:flex;gap:18px;flex-wrap:wrap}
.ag-stat{display:flex;flex-direction:column;align-items:center;min-width:64px}
.ag-statval{font-family:"JetBrains Mono",monospace;font-weight:800;font-size:1.15rem;color:#00e5ff;line-height:1.1}
.ag-statlbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.12em;color:#9fa8da}
.ag-ctrl{display:flex;gap:8px}
.ag-iconbtn{width:38px;height:38px;border-radius:10px;border:1px solid rgba(0,229,255,.25);background:rgba(0,229,255,.08);color:#e8eaf6;font-size:1rem;cursor:pointer;transition:.15s}
.ag-iconbtn:hover{background:rgba(0,229,255,.2);transform:translateY(-1px)}
.ag-stage{position:relative;height:62vh;min-height:380px;max-height:640px}
.ag-canvas{position:absolute;inset:0;width:100%;height:100%;display:block;cursor:crosshair;touch-action:none;user-select:none;-webkit-user-select:none}
.ag-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:24px;background:rgba(6,6,14,.82);backdrop-filter:blur(6px);z-index:5}
.ag-hidden{display:none!important}
.ag-kicker{font-size:.7rem;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:#00e5ff;margin-bottom:10px}
.ag-title{font-family:Outfit,Inter,sans-serif;font-weight:900;font-size:clamp(1.6rem,4vw,2.6rem);color:#e8eaf6;margin:0 0 10px;text-transform:uppercase;letter-spacing:.02em}
.ag-title.ag-best{color:#ffab00;text-shadow:0 0 30px rgba(255,171,0,.5)}
.ag-blurb{max-width:560px;color:#9fa8da;font-size:.95rem;line-height:1.55;margin:0 0 18px}
.ag-modes{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin-bottom:20px}
.ag-pill{padding:9px 18px;border-radius:999px;border:1px solid rgba(0,229,255,.3);background:rgba(0,229,255,.06);color:#9fa8da;font-weight:700;font-size:.82rem;cursor:pointer;transition:.15s;font-family:Inter,sans-serif}
.ag-pill:hover{color:#e8eaf6;background:rgba(0,229,255,.15)}
.ag-pill.ag-active{background:#00e5ff;color:#06060e;border-color:#00e5ff;box-shadow:0 0 24px rgba(0,229,255,.45)}
.ag-play{padding:16px 44px;border-radius:12px;border:none;background:linear-gradient(135deg,#00e5ff,#00b8d4);color:#06060e;font-family:Outfit,Inter,sans-serif;font-weight:900;font-size:1.15rem;letter-spacing:.06em;cursor:pointer;transition:.18s;box-shadow:0 0 34px rgba(0,229,255,.35)}
.ag-play:hover{transform:translateY(-2px) scale(1.03);box-shadow:0 0 50px rgba(0,229,255,.55)}
.ag-secondary{padding:14px 26px;border-radius:12px;border:1px solid rgba(0,229,255,.3);background:transparent;color:#9fa8da;font-weight:700;font-size:.95rem;cursor:pointer;transition:.15s}
.ag-secondary:hover{color:#e8eaf6;border-color:#00e5ff}
.ag-btnrow{display:flex;gap:12px;flex-wrap:wrap;justify-content:center}
.ag-startbest{margin-top:16px;font-family:"JetBrains Mono",monospace;font-size:.8rem;color:#ffab00}
.ag-hint{margin-top:14px;font-size:.78rem;color:#5c6bc0;max-width:460px}
.ag-hint a{color:#00e5ff;text-decoration:none}
.ag-count{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:900;font-size:clamp(4rem,14vw,9rem);color:#00e5ff;text-shadow:0 0 60px rgba(0,229,255,.6);z-index:6;pointer-events:none;animation:agPop .6s ease infinite}
@keyframes agPop{0%{transform:scale(.92);opacity:.7}50%{transform:scale(1.04);opacity:1}100%{transform:scale(.92);opacity:.7}}
.ag-resgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px;width:100%;max-width:640px;margin:0 0 20px}
.ag-rescard{background:rgba(17,17,40,.8);border:1px solid rgba(0,229,255,.15);border-radius:12px;padding:14px 8px}
.ag-resval{font-family:"JetBrains Mono",monospace;font-weight:800;font-size:1.35rem;color:#e8eaf6}
.ag-reslbl{font-size:.65rem;text-transform:uppercase;letter-spacing:.12em;color:#9fa8da;margin-top:4px}
@media (max-width:640px){.ag-stage{height:56vh;min-height:330px}.ag-statval{font-size:.95rem}.ag-stats{gap:12px}.ag-play{padding:14px 34px;font-size:1rem}}

/* ---------- game cards (homepage hero grid + hub + SEO pages) ---------- */
.ag-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;max-width:1180px;margin:0 auto}
.ag-card{position:relative;display:flex;flex-direction:column;gap:10px;padding:22px;border-radius:16px;background:linear-gradient(160deg,rgba(17,17,40,.92),rgba(10,10,24,.95));border:1px solid rgba(0,229,255,.14);text-decoration:none;overflow:hidden;transition:.2s;min-height:170px}
.ag-card::before{content:"";position:absolute;inset:0;background:radial-gradient(420px 140px at 20% 0%,rgba(0,229,255,.13),transparent 70%);opacity:.7;transition:.2s}
.ag-card:hover{transform:translateY(-4px);border-color:rgba(0,229,255,.55);box-shadow:0 14px 40px rgba(0,0,0,.45),0 0 30px rgba(0,229,255,.12)}
.ag-card:hover::before{opacity:1}
.ag-card--violet::before{background:radial-gradient(420px 140px at 20% 0%,rgba(124,77,255,.16),transparent 70%)}
.ag-card--pink::before{background:radial-gradient(420px 140px at 20% 0%,rgba(255,64,129,.14),transparent 70%)}
.ag-card--green::before{background:radial-gradient(420px 140px at 20% 0%,rgba(0,230,118,.12),transparent 70%)}
.ag-card--amber::before{background:radial-gradient(420px 140px at 20% 0%,rgba(255,171,0,.13),transparent 70%)}
.ag-card__top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.ag-card__icon{font-size:1.9rem;line-height:1;filter:drop-shadow(0 0 12px rgba(0,229,255,.45))}
.ag-card__tag{font-size:.62rem;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:#00e5ff;background:rgba(0,229,255,.1);border:1px solid rgba(0,229,255,.25);padding:4px 10px;border-radius:999px;white-space:nowrap}
.ag-card__name{font-family:Outfit,Inter,sans-serif;font-weight:800;font-size:1.25rem;color:#e8eaf6;margin:0}
.ag-card__desc{color:#9fa8da;font-size:.86rem;line-height:1.5;margin:0;flex:1}
.ag-card__cta{display:inline-flex;align-items:center;gap:8px;align-self:flex-start;margin-top:4px;padding:10px 22px;border-radius:10px;background:linear-gradient(135deg,#00e5ff,#00b8d4);color:#06060e;font-weight:900;font-size:.85rem;letter-spacing:.08em;transition:.18s}
.ag-card:hover .ag-card__cta{box-shadow:0 0 26px rgba(0,229,255,.5);transform:translateX(2px)}
.ag-card__best{position:relative;font-family:"JetBrains Mono",monospace;font-size:.68rem;color:#ffab00}

/* section heading used around grids */
.ag-section{padding:40px 20px}
.ag-section__head{text-align:center;max-width:760px;margin:0 auto 28px}
.ag-section__head h2{font-family:Outfit,Inter,sans-serif;font-weight:900;font-size:clamp(1.5rem,3.4vw,2.3rem);color:#e8eaf6;margin:0 0 10px}
.ag-section__head h2 .ag-neon{color:#00e5ff;text-shadow:0 0 26px rgba(0,229,255,.5)}
.ag-section__head p{color:#9fa8da;font-size:.95rem;line-height:1.55;margin:0}
.ag-statsbar{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:22px auto 0;max-width:880px}
.ag-statsbar__item{display:flex;flex-direction:column;align-items:center;padding:12px 22px;border-radius:12px;background:rgba(17,17,40,.7);border:1px solid rgba(0,229,255,.12);min-width:120px}
.ag-statsbar__val{font-family:"JetBrains Mono",monospace;font-weight:800;font-size:1.25rem;color:#00e5ff}
.ag-statsbar__lbl{font-size:.62rem;text-transform:uppercase;letter-spacing:.14em;color:#9fa8da}

/* promo block injected on guide pages */
.ag-promo{max-width:1180px;margin:28px auto;padding:22px 24px;border-radius:16px;background:linear-gradient(135deg,rgba(0,229,255,.10),rgba(124,77,255,.10));border:1px solid rgba(0,229,255,.3)}
.ag-promo__title{font-family:Outfit,Inter,sans-serif;font-weight:900;font-size:1.25rem;color:#e8eaf6;margin:0 0 6px}
.ag-promo__title .ag-neon{color:#00e5ff}
.ag-promo__sub{color:#9fa8da;font-size:.9rem;margin:0 0 14px;line-height:1.5}
.ag-promo__row{display:flex;gap:10px;flex-wrap:wrap}
.ag-promo__btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;font-weight:800;font-size:.85rem;text-decoration:none;transition:.15s;border:1px solid rgba(0,229,255,.35);color:#00e5ff;background:rgba(0,229,255,.07)}
.ag-promo__btn:hover{background:rgba(0,229,255,.18);transform:translateY(-1px)}
.ag-promo__btn--hot{background:linear-gradient(135deg,#00e5ff,#00b8d4);color:#06060e;border:none;box-shadow:0 0 22px rgba(0,229,255,.35)}
.ag-promo__btn--hot:hover{box-shadow:0 0 34px rgba(0,229,255,.55)}

/* breadcrumbs on game/SEO pages */
.ag-crumbs{max-width:1100px;margin:14px auto 0;padding:0 20px;font-size:.78rem;color:#5c6bc0}
.ag-crumbs a{color:#9fa8da;text-decoration:none}
.ag-crumbs a:hover{color:#00e5ff}

/* article body on game/SEO pages */
.ag-article{max-width:860px;margin:0 auto;padding:36px 20px;color:#c5cae9;font-size:.97rem;line-height:1.7}
.ag-article h2{font-family:Outfit,Inter,sans-serif;font-weight:800;color:#e8eaf6;font-size:1.45rem;margin:34px 0 12px}
.ag-article h3{color:#e8eaf6;font-size:1.1rem;margin:24px 0 8px}
.ag-article p{margin:0 0 14px}
.ag-article ul,.ag-article ol{margin:0 0 16px;padding-left:22px}
.ag-article li{margin-bottom:6px}
.ag-article a{color:#00e5ff;text-decoration:none}
.ag-article a:hover{text-decoration:underline}
.ag-article table{width:100%;border-collapse:collapse;margin:14px 0 20px;font-size:.88rem}
.ag-article th,.ag-article td{border:1px solid rgba(0,229,255,.15);padding:9px 12px;text-align:left}
.ag-article th{background:rgba(0,229,255,.08);color:#e8eaf6}
.ag-faq details{border:1px solid rgba(0,229,255,.15);border-radius:12px;background:rgba(17,17,40,.6);margin-bottom:10px;padding:0 16px}
.ag-faq summary{cursor:pointer;font-weight:700;color:#e8eaf6;padding:14px 0;list-style:none}
.ag-faq summary::-webkit-details-marker{display:none}
.ag-faq summary::before{content:"▸ ";color:#00e5ff}
.ag-faq details[open] summary::before{content:"▾ "}
.ag-faq details p{padding-bottom:14px;margin:0;color:#9fa8da}
