/* ═══════════════════════════════════════════════════════════════
   NOVA TEAM NTC  ·  styles.css  ·  v3.0 PROFESSIONAL
   ═══════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@300;400;500;600;700&display=swap');

/* ── Variables ──────────────────────────────────────────────── */
:root {
    --green:        #39ff14;
    --green-dim:    #27b30e;
    --green-glow:   rgba(57,255,20,0.18);
    --blue:         #00bfff;
    --dark:         #0a0a0a;
    --dark2:        #111111;
    --dark3:        #161616;
    --glass-bg:     rgba(255,255,255,0.045);
    --glass-border: rgba(57,255,20,0.14);
    --red:          #ff4d4d;
    --sidebar-w:    230px;
    --radius:       14px;
    --radius-sm:    8px;
    --nav-h:        64px;
    --ease:         cubic-bezier(0.25, 0.46, 0.45, 0.94);
    --ease-bounce:  cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-tap-highlight-color:transparent; }
body {
    font-family:'Poppins',sans-serif;
    background:var(--dark);
    color:#fff;
    overflow-x:hidden;
    min-height:100vh;
}
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; height:auto; }
input,textarea,button { font-family:inherit; }
button { cursor:pointer; background:transparent; border:none; }

/* ── Partículas (canvas creado por JS) ──────────────────────── */
#nova-particles,
canvas[aria-hidden] {
    position:fixed;
    inset:0;
    z-index:0;
    pointer-events:none;
}

/* ── Barra de scroll progress ───────────────────────────────── */
.scroll-bar {
    position:fixed;
    top:0; left:0;
    width:100%;
    height:2px;
    background:var(--green);
    transform:scaleX(0);
    transform-origin:left;
    z-index:9999;
    box-shadow:0 0 8px var(--green), 0 0 20px rgba(57,255,20,0.4);
    transition:transform 0.1s linear;
}

/* ── Cursor glow ─────────────────────────────────────────────── */
.cursor-glow {
    position:fixed;
    width:380px;
    height:380px;
    border-radius:50%;
    pointer-events:none;
    background:radial-gradient(
        circle,
        rgba(57,255,20,0.055) 0%,
        transparent 65%
    );
    z-index:1;
    transform:translate(-50%,-50%);
    transition:opacity 0.3s ease;
    will-change:transform;
}

/* ── Ripple ──────────────────────────────────────────────────── */
.btn-neon, .btn-ghost { position:relative; overflow:hidden; }
.btn-ripple {
    position:absolute;
    border-radius:50%;
    width:4px; height:4px;
    background:rgba(255,255,255,0.4);
    transform:translate(-50%,-50%) scale(0);
    animation:ripple 0.5s ease-out forwards;
    pointer-events:none;
}
@keyframes ripple {
    to { transform:translate(-50%,-50%) scale(80); opacity:0; }
}

/* ── Glass ───────────────────────────────────────────────────── */
.glass {
    background:var(--glass-bg);
    backdrop-filter:blur(18px);
    -webkit-backdrop-filter:blur(18px);
    border:1px solid var(--glass-border);
    border-radius:var(--radius);
}

/* ── Preloader ───────────────────────────────────────────────── */
#preloader {
    position:fixed;
    inset:0;
    z-index:9999;
    background:radial-gradient(ellipse at center,#0d1b2a 0%,#000 100%);
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    transition:opacity 0.6s ease, visibility 0.6s ease;
}
#preloader.hidden {
    opacity:0;
    visibility:hidden;
    pointer-events:none;
}
#preloader img {
    width:110px;
    height:110px;
    object-fit:contain;
    animation:preloaderPulse 1.8s ease-in-out infinite;
}

/* ── Navbar ──────────────────────────────────────────────────── */
.navbar {
    position:fixed;
    top:0; left:0; right:0;
    z-index:1000;
    height:var(--nav-h);
    padding:0 32px;
    background:rgba(10,10,10,0.72);
    backdrop-filter:blur(14px);
    -webkit-backdrop-filter:blur(14px);
    border-bottom:1px solid rgba(57,255,20,0.06);
    transition:background 0.3s ease, border-color 0.3s ease;
}
.navbar.scrolled {
    background:rgba(10,10,10,0.94);
    border-bottom-color:rgba(57,255,20,0.12);
}
.nav-container {
    display:flex;
    justify-content:space-between;
    align-items:center;
    height:100%;
    max-width:1200px;
    margin:0 auto;
}
.nav-logo {
    display:flex;
    align-items:center;
    gap:10px;
}
.nav-logo img {
    width:36px; height:36px;
    max-width:36px;
    object-fit:contain;
    animation:glowPulse 2.8s ease-in-out infinite alternate;
    flex-shrink:0;
}
.nav-logo span { font-size:1.05rem; font-weight:600; color:var(--green); }
.nav-links {
    display:flex;
    align-items:center;
    gap:26px;
}
.nav-links a {
    font-size:0.88rem;
    font-weight:500;
    color:rgba(255,255,255,0.75);
    transition:color 0.2s ease;
    display:flex;
    align-items:center;
    gap:5px;
    position:relative;
}
.nav-links a::after {
    content:'';
    position:absolute;
    bottom:-3px; left:0; right:0;
    height:1px;
    background:var(--green);
    transform:scaleX(0);
    transition:transform 0.2s ease;
}
.nav-links a:not(.btn-neon):hover::after,
.nav-links a.active::after { transform:scaleX(1); }
.nav-links a i { font-size:1.05rem; }
.nav-links a:hover,
.nav-links a.active { color:var(--green); }

/* ── Hamburger ───────────────────────────────────────────────── */
.hamburger {
    display:none;
    flex-direction:column;
    gap:5px;
    cursor:pointer;
    z-index:1100;
    padding:6px;
    background:transparent;
    border:none;
}
.hamburger span {
    display:block;
    width:22px; height:2px;
    background:var(--green);
    border-radius:2px;
    transition:transform 0.3s var(--ease), opacity 0.2s ease;
}
.hamburger.active span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.active span:nth-child(2) { opacity:0; transform:scaleX(0); }
.hamburger.active span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ── Btn Neon ────────────────────────────────────────────────── */
.btn-neon {
    display:inline-flex;
    align-items:center;
    gap:7px;
    padding:10px 24px;
    border:1px solid var(--green);
    border-radius:var(--radius-sm);
    color:var(--green);
    font-weight:600;
    font-size:0.88rem;
    background:transparent;
    cursor:pointer;
    transition:background 0.22s ease, color 0.22s ease, box-shadow 0.22s ease, transform 0.18s var(--ease-bounce);
    text-shadow:0 0 8px rgba(57,255,20,0.5);
    box-shadow:0 0 8px rgba(57,255,20,0.15), inset 0 0 0 0 var(--green);
    white-space:nowrap;
    user-select:none;
}
.btn-neon:hover {
    background:var(--green);
    color:#000;
    box-shadow:0 0 24px rgba(57,255,20,0.5), 0 0 60px rgba(57,255,20,0.15);
    text-shadow:none;
}
.btn-neon:active { transform:scale(0.96) !important; }

.btn-ghost {
    display:inline-flex;
    align-items:center;
    gap:7px;
    padding:10px 20px;
    border:1px solid rgba(255,255,255,0.14);
    border-radius:var(--radius-sm);
    color:rgba(255,255,255,0.55);
    background:transparent;
    cursor:pointer;
    font-size:0.88rem;
    transition:border-color 0.2s, color 0.2s, transform 0.18s var(--ease-bounce);
    white-space:nowrap;
}
.btn-ghost:hover { border-color:rgba(255,255,255,0.4); color:#fff; }
.btn-ghost:active { transform:scale(0.96) !important; }
.back-btn { margin-bottom:24px; }

/* ── Hero ────────────────────────────────────────────────────── */
.hero {
    position:relative;
    z-index:1;
    min-height:100vh;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    text-align:center;
    padding:var(--nav-h) 24px 40px;
}
.hero h1 {
    font-size:clamp(2.2rem,5.5vw,4rem);
    font-weight:700;
    background:linear-gradient(135deg,#fff 30%,var(--green));
    -webkit-background-clip:text;
    -webkit-text-fill-color:transparent;
    background-clip:text;
    margin-bottom:20px;
    line-height:1.15;
    animation:fadeInUp 0.7s var(--ease) both;
}
.hero p {
    font-size:clamp(1rem,2vw,1.18rem);
    color:rgba(255,255,255,0.6);
    max-width:520px;
    margin-bottom:40px;
    line-height:1.75;
    animation:fadeInUp 0.7s var(--ease) 0.15s both;
}
.hero .btn-neon {
    animation:fadeInUp 0.7s var(--ease) 0.3s both;
}

/* ── Featured Nova Guard ─────────────────────────────────────── */
.nova-guard-featured {
    position:relative;
    z-index:1;
    padding:0 24px 48px;
    max-width:1200px;
    margin:0 auto;
    animation:fadeInUp 0.6s var(--ease) 0.45s both;
}
.nova-guard-card {
    display:flex;
    align-items:center;
    gap:24px;
    padding:28px 32px;
    background:rgba(57,255,20,0.04);
    border:1px solid rgba(57,255,20,0.2);
    border-radius:var(--radius);
    transition:background 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}
.nova-guard-card:hover {
    background:rgba(57,255,20,0.09);
    box-shadow:0 0 40px rgba(57,255,20,0.12);
    border-color:rgba(57,255,20,0.35);
}
.nova-guard-card .ng-icon { font-size:2.8rem; line-height:1; flex-shrink:0; }
.nova-guard-card .ng-info { flex:1; }
.nova-guard-card h3 { font-size:1.15rem; font-weight:700; color:#fff; margin-bottom:4px; }
.nova-guard-card p { color:rgba(255,255,255,0.5); font-size:0.86rem; line-height:1.55; }
.nova-guard-card .ng-arrow { font-size:2rem; color:var(--green); flex-shrink:0; transition:transform 0.25s var(--ease-bounce); }
.nova-guard-card:hover .ng-arrow { transform:translateX(4px); }
.play-badge {
    font-size:0.7rem;
    background:rgba(57,255,20,0.12);
    border:1px solid rgba(57,255,20,0.35);
    color:var(--green);
    padding:2px 10px;
    border-radius:20px;
    font-weight:600;
    margin-left:10px;
}

/* ── Sections ────────────────────────────────────────────────── */
.games-section,
.about-section {
    position:relative;
    z-index:1;
    padding:80px 24px;
    max-width:1200px;
    margin:0 auto;
}
.games-section h2,
.about-section h2 {
    font-size:2rem;
    text-align:center;
    color:var(--green);
    margin-bottom:10px;
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
}
.games-section > p,
.about-section > p {
    text-align:center;
    color:rgba(255,255,255,0.5);
    margin-bottom:40px;
}
.about-section {
    max-width:700px;
    text-align:center;
}

/* ── Games Grid ──────────────────────────────────────────────── */
.games-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
    gap:22px;
}
.game-card {
    display:flex;
    flex-direction:column;
    gap:10px;
    padding:22px;
    transition:transform 0.25s var(--ease), box-shadow 0.25s ease;
    will-change:transform;
}
.game-card:hover {
    transform:translateY(-5px);
    box-shadow:0 8px 32px rgba(57,255,20,0.12);
}
.game-card-header {
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:10px;
}
.game-card h3 { font-size:1.02rem; font-weight:600; }
.game-card > p { font-size:0.86rem; color:rgba(255,255,255,0.58); line-height:1.65; flex:1; }
.card-arrow {
    font-size:1.2rem;
    color:rgba(57,255,20,0.4);
    margin-top:auto;
    transition:color 0.2s, transform 0.2s var(--ease-bounce);
    align-self:flex-end;
}
.game-card:hover .card-arrow { color:var(--green); transform:translateX(3px); }

/* ── Badges ──────────────────────────────────────────────────── */
.version-badge {
    font-size:0.7rem;
    background:rgba(57,255,20,0.1);
    border:1px solid rgba(57,255,20,0.28);
    color:var(--green);
    padding:2px 8px;
    border-radius:20px;
    white-space:nowrap;
    flex-shrink:0;
}
.platform-badge {
    font-size:0.7rem;
    background:rgba(0,191,255,0.1);
    border:1px solid rgba(0,191,255,0.28);
    color:var(--blue);
    padding:2px 8px;
    border-radius:20px;
    align-self:flex-start;
}

/* ── Page Main ───────────────────────────────────────────────── */
.page-main {
    position:relative;
    z-index:1;
    max-width:1200px;
    margin:0 auto;
    padding:calc(var(--nav-h) + 36px) 24px 60px;
}
.page-header {
    text-align:center;
    margin-bottom:44px;
}
.page-header h1 {
    font-size:clamp(1.8rem,4vw,2.6rem);
    font-weight:700;
    color:var(--green);
    display:flex;
    align-items:center;
    justify-content:center;
    gap:10px;
}
.page-header p { color:rgba(255,255,255,0.48); margin-top:8px; }

/* ── Game Detail ─────────────────────────────────────────────── */
.game-detail {
    max-width:720px;
    margin:calc(var(--nav-h) + 24px) auto 60px;
    padding:40px;
}
.game-detail h1 { font-size:2rem; margin-bottom:16px; }
.game-detail .badges { display:flex; gap:10px; flex-wrap:wrap; margin-bottom:20px; }
.game-detail p { color:rgba(255,255,255,0.68); line-height:1.85; margin-bottom:16px; }
.game-detail .meta { font-size:0.84rem; opacity:0.45; }

/* ── News ────────────────────────────────────────────────────── */
.news-list { display:flex; flex-direction:column; gap:18px; }
.news-card { padding:28px; }
.news-card h3 { font-size:1.08rem; font-weight:600; margin-bottom:8px; }
.news-date {
    font-size:0.78rem;
    color:var(--green);
    margin-bottom:12px;
    display:flex;
    align-items:center;
    gap:4px;
}
.news-card > p { color:rgba(255,255,255,0.62); line-height:1.75; font-size:0.9rem; }

/* ── Form Pages ──────────────────────────────────────────────── */
.form-page {
    position:relative;
    z-index:1;
    min-height:100vh;
    display:flex;
    justify-content:center;
    align-items:center;
    padding:24px;
}
.form-box {
    width:100%;
    max-width:420px;
    padding:40px 36px;
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:8px;
}
.form-logo {
    width:68px; height:68px;
    max-width:68px;
    object-fit:contain;
    flex-shrink:0;
    margin-bottom:6px;
    animation:glowPulse 3s ease-in-out infinite;
}
.form-box h2 {
    font-size:1.3rem;
    font-weight:700;
    color:#fff;
    margin-bottom:14px;
}
.form-box form {
    width:100%;
    display:flex;
    flex-direction:column;
    gap:11px;
}
.input-wrap {
    position:relative;
    width:100%;
}
.input-wrap i {
    position:absolute;
    right:13px;
    top:50%;
    transform:translateY(-50%);
    color:rgba(255,255,255,0.3);
    cursor:pointer;
    font-size:1.1rem;
    transition:color 0.2s;
}
.input-wrap i:hover { color:rgba(255,255,255,0.7); }
.form-box input[type="text"],
.form-box input[type="email"],
.form-box input[type="password"] {
    width:100%;
    padding:12px 16px;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.1);
    border-radius:var(--radius-sm);
    color:#fff;
    font-size:0.9rem;
    transition:border-color 0.2s, background 0.2s;
    outline:none;
}
.form-box input:focus {
    border-color:var(--green);
    background:rgba(57,255,20,0.03);
}
.form-box input.pr { padding-right:42px; }
.form-box .terms {
    display:flex;
    align-items:center;
    gap:10px;
    font-size:0.84rem;
    color:rgba(255,255,255,0.55);
    cursor:pointer;
}
.form-box .terms input[type="checkbox"] { accent-color:var(--green); }
.msg {
    font-size:0.84rem;
    min-height:20px;
    text-align:center;
    padding:6px 0;
    transition:color 0.2s;
}
.msg.error   { color:var(--red); }
.msg.success { color:var(--green); }
.msg.neutral { color:rgba(255,255,255,0.45); }
.link-text {
    font-size:0.84rem;
    color:rgba(255,255,255,0.45);
    margin-top:4px;
}
.link-text a { color:var(--green); }

/* ── Password strength ───────────────────────────────────────── */
.pass-strength {
    font-size:0.75rem;
    margin-top:-6px;
    transition:color 0.2s;
}
.pass-strength.weak   { color:#ff4d4d; }
.pass-strength.fair   { color:#ffa500; }
.pass-strength.good   { color:#cfff04; }
.pass-strength.strong { color:var(--green); }

/* ── Profile ─────────────────────────────────────────────────── */
.profile-box {
    width:100%;
    max-width:520px;
    padding:40px;
    text-align:center;
    margin-top:30px;
}
.profile-avatar {
    width:82px; height:82px;
    max-width:82px;
    object-fit:cover;
    border-radius:50%;
    border:2px solid var(--green);
    margin:0 auto 16px;
    box-shadow:0 0 20px rgba(57,255,20,0.25);
}
.profile-username { font-size:1.4rem; font-weight:700; margin-bottom:4px; }
.profile-role { font-size:0.86rem; color:var(--green); margin-bottom:6px; }
.profile-admin-link {
    margin-top:20px;
    border-top:1px solid var(--glass-border);
    padding-top:18px;
}
.achievements-list { display:flex; flex-direction:column; gap:10px; }
.achievement-item {
    padding:11px 16px;
    background:rgba(57,255,20,0.05);
    border:1px solid rgba(57,255,20,0.13);
    border-radius:var(--radius-sm);
    font-size:0.86rem;
    text-align:left;
    display:flex;
    align-items:center;
    gap:10px;
    transition:background 0.2s;
}
.achievement-item:hover { background:rgba(57,255,20,0.09); }
.ach-icon { font-size:1.3rem; flex-shrink:0; }
.ach-info { flex:1; display:flex; flex-direction:column; gap:2px; }
.ach-info strong { font-size:0.88rem; }
.ach-info small { font-size:0.75rem; color:rgba(255,255,255,0.45); }
.ach-date { font-size:0.74rem; color:rgba(255,255,255,0.3); flex-shrink:0; }

/* ── Footer ──────────────────────────────────────────────────── */
footer {
    position:relative;
    z-index:1;
    text-align:center;
    padding:26px 24px;
    color:rgba(255,255,255,0.28);
    font-size:0.8rem;
    border-top:1px solid rgba(57,255,20,0.05);
}

/* ── Empty / Loading ─────────────────────────────────────────── */
.empty-msg {
    text-align:center;
    color:rgba(255,255,255,0.32);
    padding:40px 0;
    font-size:0.9rem;
}

/* ── Skeleton loader ─────────────────────────────────────────── */
.skeleton-card {
    padding:24px;
    pointer-events:none;
}
.sk {
    border-radius:6px;
    background:linear-gradient(
        90deg,
        rgba(255,255,255,0.04) 25%,
        rgba(255,255,255,0.09) 50%,
        rgba(255,255,255,0.04) 75%
    );
    background-size:200% 100%;
    animation:shimmer 1.5s ease-in-out infinite;
}
.sk-title { height:20px; width:55%; margin-bottom:12px; }
.sk-text  { height:13px; width:100%; margin-bottom:8px; }
.sk-short { width:70%; }
@keyframes shimmer {
    0%   { background-position:200% 0; }
    100% { background-position:-200% 0; }
}

/* ── Scroll animations ───────────────────────────────────────── */
.anim {
    opacity:0;
    transform:translateY(22px);
    transition:opacity 0.5s var(--ease), transform 0.5s var(--ease);
}
.anim.in-view {
    opacity:1;
    transform:none;
}

/* ═════════════════════════════════════════════════════════════
   ADMIN PANEL
   ═════════════════════════════════════════════════════════════ */
.admin-body { background:var(--dark); overflow:hidden; }
.admin-wrapper { display:flex; min-height:100vh; }

/* ── Sidebar ─────────────────────────────────────────────────── */
.sidebar {
    position:fixed;
    top:0; left:0;
    width:var(--sidebar-w);
    height:100vh;
    background:rgba(10,10,10,0.96);
    border-right:1px solid rgba(57,255,20,0.08);
    display:flex;
    flex-direction:column;
    z-index:500;
    padding-bottom:20px;
}
.sidebar-logo {
    display:flex;
    align-items:center;
    gap:10px;
    padding:22px 20px 20px;
    border-bottom:1px solid rgba(57,255,20,0.08);
    margin-bottom:12px;
}
.sidebar-logo img { width:32px; height:32px; object-fit:contain; flex-shrink:0; }
.sidebar-logo span { font-size:0.9rem; font-weight:700; color:var(--green); }
.sidebar-nav { flex:1; display:flex; flex-direction:column; }
.sidebar-link {
    display:flex;
    align-items:center;
    gap:12px;
    padding:12px 20px;
    font-size:0.86rem;
    color:rgba(255,255,255,0.52);
    transition:color 0.2s, background 0.2s, border-color 0.2s;
    border-left:2px solid transparent;
}
.sidebar-link i { font-size:1.15rem; }
.sidebar-link:hover,
.sidebar-link.active { color:var(--green); border-left-color:var(--green); background:rgba(57,255,20,0.05); }
.sidebar-logout {
    display:flex;
    align-items:center;
    gap:12px;
    padding:12px 20px;
    font-size:0.86rem;
    color:var(--red);
    transition:background 0.2s;
    margin-top:auto;
    cursor:pointer;
}
.sidebar-logout:hover { background:rgba(255,77,77,0.07); }

/* ── Admin Main ──────────────────────────────────────────────── */
.admin-main {
    margin-left:var(--sidebar-w);
    flex:1;
    padding:32px 36px;
    position:relative;
    z-index:1;
    overflow-y:auto;
    min-height:100vh;
}
.admin-header {
    display:flex;
    justify-content:space-between;
    align-items:center;
    margin-bottom:32px;
    flex-wrap:wrap;
    gap:14px;
}
.admin-header h1 {
    font-size:1.55rem;
    font-weight:700;
    display:flex;
    align-items:center;
    gap:10px;
}
.admin-header h1 i { color:var(--green); }
.admin-header p { color:rgba(255,255,255,0.48); font-size:0.86rem; }
.admin-date { font-size:0.8rem; color:rgba(255,255,255,0.32); text-transform:capitalize; }

/* ── Stats ───────────────────────────────────────────────────── */
.stats-grid {
    display:grid;
    grid-template-columns:repeat(auto-fill,minmax(180px,1fr));
    gap:18px;
    margin-bottom:30px;
}
.stat-card { display:flex; align-items:center; gap:14px; padding:20px; }
.stat-icon { font-size:2.1rem; color:var(--green); }
.stat-number { display:block; font-size:1.9rem; font-weight:700; line-height:1; }
.stat-label  { display:block; font-size:0.78rem; color:rgba(255,255,255,0.42); margin-top:3px; }
.quick-links { display:flex; flex-wrap:wrap; gap:12px; margin-bottom:30px; }
.recent-section { padding:22px; }
.recent-section h2 { font-size:1.05rem; font-weight:600; margin-bottom:16px; display:flex; align-items:center; gap:8px; }
.recent-section h2 i { color:var(--green); }

/* ── Table ───────────────────────────────────────────────────── */
.table-wrapper { overflow-x:auto; }
.admin-table { width:100%; border-collapse:collapse; font-size:0.86rem; }
.admin-table thead tr { background:rgba(57,255,20,0.04); border-bottom:1px solid rgba(57,255,20,0.1); }
.admin-table th {
    padding:12px 16px;
    text-align:left;
    font-weight:600;
    color:rgba(255,255,255,0.65);
    font-size:0.76rem;
    text-transform:uppercase;
    letter-spacing:0.04em;
}
.admin-table td { padding:11px 16px; border-bottom:1px solid rgba(255,255,255,0.035); vertical-align:middle; }
.admin-table tbody tr:hover { background:rgba(255,255,255,0.018); }
.td-truncate { max-width:200px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; color:rgba(255,255,255,0.52); }
.empty-row { text-align:center; padding:26px; color:rgba(255,255,255,0.28); }

/* ── Role Badges ─────────────────────────────────────────────── */
.role-badge {
    display:inline-flex;
    align-items:center;
    gap:4px;
    padding:3px 10px;
    border-radius:20px;
    font-size:0.73rem;
    font-weight:600;
    text-transform:capitalize;
}
.role-badge.admin { background:rgba(57,255,20,0.1); border:1px solid rgba(57,255,20,0.28); color:var(--green); }
.role-badge.user  { background:rgba(0,191,255,0.08); border:1px solid rgba(0,191,255,0.22); color:var(--blue); }

/* ── Icon Buttons ────────────────────────────────────────────── */
.td-actions { display:flex; gap:7px; align-items:center; }
.btn-icon {
    width:32px; height:32px;
    border-radius:var(--radius-sm);
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
    border:none;
    transition:background 0.2s;
    font-size:0.95rem;
}
.btn-icon.edit   { background:rgba(0,191,255,0.1); color:var(--blue); border:1px solid rgba(0,191,255,0.18); }
.btn-icon.delete { background:rgba(255,77,77,0.09); color:var(--red); border:1px solid rgba(255,77,77,0.18); }
.btn-icon.edit:hover   { background:rgba(0,191,255,0.22); }
.btn-icon.delete:hover { background:rgba(255,77,77,0.22); }

/* ── Modals ──────────────────────────────────────────────────── */
.modal-overlay {
    position:fixed;
    inset:0;
    background:rgba(0,0,0,0.72);
    z-index:2000;
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
    backdrop-filter:blur(6px);
    animation:fadeIn 0.2s ease;
}
.modal-box { width:100%; max-width:480px; padding:36px; }
.modal-box h2 { font-size:1.2rem; font-weight:700; margin-bottom:22px; display:flex; align-items:center; gap:10px; }
.modal-box h2 i { color:var(--green); }
.modal-box input[type="text"],
.modal-box input[type="email"],
.modal-box input[type="password"],
.modal-box textarea {
    width:100%;
    padding:11px 14px;
    margin-bottom:11px;
    background:rgba(255,255,255,0.05);
    border:1px solid rgba(255,255,255,0.1);
    border-radius:var(--radius-sm);
    color:#fff;
    font-size:0.88rem;
    outline:none;
    transition:border-color 0.2s;
    resize:vertical;
}
.modal-box input:focus,
.modal-box textarea:focus { border-color:var(--green); }
.modal-actions { display:flex; gap:11px; margin-top:8px; flex-wrap:wrap; }

/* ── Alert ───────────────────────────────────────────────────── */
.alert-msg {
    padding:11px 16px;
    border-radius:var(--radius-sm);
    font-size:0.86rem;
    margin-bottom:18px;
}
.alert-msg.success { background:rgba(57,255,20,0.07); border:1px solid rgba(57,255,20,0.18); color:var(--green); }
.alert-msg.error   { background:rgba(255,77,77,0.07); border:1px solid rgba(255,77,77,0.18); color:var(--red); }

/* ── Animaciones ─────────────────────────────────────────────── */
@keyframes glowPulse {
    0%   { filter:drop-shadow(0 0 3px var(--green)); opacity:.85; }
    100% { filter:drop-shadow(0 0 12px var(--green)) drop-shadow(0 0 26px var(--green)); opacity:1; }
}
@keyframes preloaderPulse {
    0%   { transform:scale(1);    filter:drop-shadow(0 0 8px var(--green)) drop-shadow(0 0 20px var(--green)); opacity:1; }
    45%  { transform:scale(1.07); filter:drop-shadow(0 0 20px var(--green)) drop-shadow(0 0 45px var(--green)); opacity:1; }
    100% { transform:scale(1);    filter:drop-shadow(0 0 8px var(--green)) drop-shadow(0 0 20px var(--green)); opacity:1; }
}
@keyframes fadeInUp {
    from { opacity:0; transform:translateY(22px); }
    to   { opacity:1; transform:none; }
}
@keyframes fadeIn {
    from { opacity:0; }
    to   { opacity:1; }
}

/* ── View Transitions ────────────────────────────────────────── */
::view-transition-old(root) {
    animation:0.22s ease both fade-out;
}
::view-transition-new(root) {
    animation:0.25s var(--ease) both fade-in-up;
}
@keyframes fade-out    { to   { opacity:0; transform:translateY(-8px); } }
@keyframes fade-in-up  { from { opacity:0; transform:translateY(10px); } }

/* ── Scrollbar ───────────────────────────────────────────────── */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:#0a0a0a; }
::-webkit-scrollbar-thumb { background:rgba(57,255,20,0.22); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:rgba(57,255,20,0.42); }

/* ═════════════════════════════════════════════════════════════
   RESPONSIVE
   ═════════════════════════════════════════════════════════════ */
@media (max-width:768px) {
    .nav-links {
        position:fixed;
        top:0; right:-100%;
        width:75%;
        max-width:280px;
        height:100vh;
        background:rgba(10,10,10,0.98);
        flex-direction:column;
        align-items:flex-start;
        padding:80px 26px 26px;
        gap:4px;
        transition:right 0.35s var(--ease);
        border-left:1px solid rgba(57,255,20,0.08);
        z-index:1050;
    }
    .nav-links.open { right:0; }
    .nav-links a { font-size:1rem; padding:10px 0; width:100%; }
    .nav-links a::after { display:none; }
    .hamburger { display:flex; }

    .hero { padding-top:calc(var(--nav-h) + 20px); }
    .games-section, .about-section { padding:60px 18px; }
    .page-main { padding:calc(var(--nav-h) + 20px) 16px 40px; }
    .nova-guard-card { flex-direction:column; align-items:flex-start; gap:14px; }
    .nova-guard-card .ng-arrow { align-self:flex-end; }

    /* Admin */
    .sidebar { transform:translateX(-100%); transition:transform 0.3s var(--ease); z-index:600; }
    .sidebar.open { transform:translateX(0); }
    .admin-main { margin-left:0; padding:20px 16px; }
    .stats-grid { grid-template-columns:repeat(2,1fr); }
    .admin-header { flex-direction:column; align-items:flex-start; }

    .cursor-glow { display:none; }
}

@media (max-width:480px) {
    .form-box { padding:28px 18px; }
    .game-detail { padding:22px; margin:calc(var(--nav-h) + 12px) 14px 40px; }
    .stats-grid { grid-template-columns:1fr; }
    .modal-box { padding:22px; }
    .profile-box { padding:28px 20px; }
}

/* ═════════════════════════════════════════════════════════════
   NOVA LAUNCHER — Componentes específicos del launcher
   ═════════════════════════════════════════════════════════════ */

/* ── Launcher badge (en tarjetas) ───────────────────────────── */
.launcher-required-badge {
    font-size:0.69rem;
    background:rgba(57,255,20,0.08);
    border:1px solid rgba(57,255,20,0.22);
    color:var(--green);
    padding:2px 8px;
    border-radius:20px;
    display:inline-flex;
    align-items:center;
    gap:4px;
    white-space:nowrap;
}
.game-card-footer {
    display:flex;
    align-items:center;
    gap:8px;
    flex-wrap:wrap;
    margin-top:2px;
}

/* ── Botón Launcher (acción primaria de jugar) ───────────────── */
.btn-launcher {
    display:inline-flex;
    align-items:center;
    gap:8px;
    padding:13px 32px;
    background:var(--green);
    color:#000;
    font-weight:700;
    font-size:0.95rem;
    border:none;
    border-radius:var(--radius-sm);
    cursor:pointer;
    position:relative;
    overflow:hidden;
    transition:box-shadow 0.25s ease, transform 0.18s var(--ease-bounce), filter 0.2s ease;
    box-shadow:0 0 20px rgba(57,255,20,0.35);
    user-select:none;
}
.btn-launcher:hover {
    box-shadow:0 0 40px rgba(57,255,20,0.55), 0 4px 20px rgba(57,255,20,0.25);
    filter:brightness(1.1);
}
.btn-launcher:active { transform:scale(0.96) !important; }
.btn-launcher:disabled { opacity:0.7; cursor:not-allowed; }

/* ── Acciones en juego detail ────────────────────────────────── */
.game-actions {
    display:flex;
    gap:12px;
    flex-wrap:wrap;
    align-items:center;
    margin-top:28px;
}

/* ── Sección descarga del launcher ───────────────────────────── */
.launcher-section {
    position:relative;
    z-index:1;
    padding:80px 24px;
    max-width:1200px;
    margin:0 auto;
    text-align:center;
}
.launcher-section h2 {
    font-size:clamp(1.6rem,3.5vw,2.4rem);
    font-weight:700;
    color:#fff;
    margin-bottom:14px;
}
.launcher-section h2 span { color:var(--green); }
.launcher-section > p {
    color:rgba(255,255,255,0.52);
    max-width:540px;
    margin:0 auto 40px;
    line-height:1.75;
}
.launcher-features {
    display:grid;
    grid-template-columns:repeat(auto-fit,minmax(200px,1fr));
    gap:20px;
    margin-bottom:44px;
}
.launcher-feature {
    padding:22px 20px;
    text-align:center;
    transition:transform 0.25s var(--ease), box-shadow 0.25s ease;
}
.launcher-feature:hover {
    transform:translateY(-4px);
    box-shadow:0 8px 28px rgba(57,255,20,0.1);
}
.launcher-feature-icon {
    font-size:2rem;
    margin-bottom:12px;
    display:block;
}
.launcher-feature h3 { font-size:0.95rem; font-weight:600; margin-bottom:6px; }
.launcher-feature p  { font-size:0.82rem; color:rgba(255,255,255,0.5); line-height:1.6; }

.launcher-download-box {
    display:inline-flex;
    flex-direction:column;
    align-items:center;
    gap:14px;
    padding:32px 40px;
    border:1px solid rgba(57,255,20,0.2);
    border-radius:var(--radius);
    background:rgba(57,255,20,0.03);
}
.launcher-download-box .version-info {
    font-size:0.78rem;
    color:rgba(255,255,255,0.35);
}
.launcher-download-box .sys-req {
    font-size:0.76rem;
    color:rgba(255,255,255,0.3);
}

/* ── Modal de descarga ───────────────────────────────────────── */
.launcher-modal-overlay {
    position:fixed;
    inset:0;
    z-index:3000;
    background:rgba(0,0,0,0.75);
    display:flex;
    align-items:center;
    justify-content:center;
    padding:20px;
    backdrop-filter:blur(6px);
    opacity:0;
    pointer-events:none;
    transition:opacity 0.25s ease;
}
.launcher-modal-overlay.visible {
    opacity:1;
    pointer-events:all;
}
.launcher-modal-box {
    width:100%;
    max-width:440px;
    padding:36px;
    text-align:center;
    position:relative;
    transform:translateY(20px);
    transition:transform 0.3s var(--ease-bounce);
}
.launcher-modal-overlay.visible .launcher-modal-box { transform:none; }
.launcher-modal-close {
    position:absolute;
    top:14px; right:14px;
    width:32px; height:32px;
    display:flex; align-items:center; justify-content:center;
    background:rgba(255,255,255,0.06);
    border:none; border-radius:50%;
    color:rgba(255,255,255,0.5);
    cursor:pointer; font-size:1.2rem;
    transition:background 0.2s, color 0.2s;
}
.launcher-modal-close:hover { background:rgba(255,255,255,0.12); color:#fff; }
.launcher-modal-icon { font-size:3rem; margin-bottom:16px; }
.launcher-modal-box h2 { font-size:1.25rem; font-weight:700; margin-bottom:10px; }
.launcher-modal-box > p { font-size:0.88rem; color:rgba(255,255,255,0.6); line-height:1.6; margin-bottom:20px; }
.launcher-modal-box strong { color:#fff; }
.launcher-modal-steps {
    display:flex;
    flex-direction:column;
    gap:10px;
    margin-bottom:22px;
    text-align:left;
}
.lm-step {
    display:flex;
    align-items:center;
    gap:12px;
    font-size:0.86rem;
    color:rgba(255,255,255,0.65);
}
.lm-step span {
    width:24px; height:24px; flex-shrink:0;
    background:rgba(57,255,20,0.12);
    border:1px solid rgba(57,255,20,0.3);
    border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    font-size:0.75rem;
    color:var(--green);
    font-weight:700;
}
.launcher-modal-cancel { margin-top:6px; }

/* ═════════════════════════════════════════════════════════════
   AUTH — Navbar user widget, login page, perfil, admin
   ═════════════════════════════════════════════════════════════ */

/* ── Nav user widget ─────────────────────────────────────────── */
.nav-user-widget { position:relative; display:flex; align-items:center; }
.nav-user-btn {
    display:flex; align-items:center; gap:7px;
    background:rgba(57,255,20,.07); border:1px solid rgba(57,255,20,.18);
    border-radius:24px; padding:4px 12px 4px 5px;
    cursor:pointer; transition:background .18s, box-shadow .18s; color:#fff;
}
.nav-user-btn:hover { background:rgba(57,255,20,.12); box-shadow:0 0 14px rgba(57,255,20,.18); }
.nav-user-name { font-size:.8rem; font-weight:600; max-width:100px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.nav-user-chevron { font-size:1rem; color:rgba(255,255,255,.5); transition:transform .2s; }
.nav-user-chevron.rotated { transform:rotate(180deg); }

.nav-user-dropdown {
    position:absolute; top:calc(100% + 10px); right:0;
    width:220px; background:#111; border:1px solid rgba(57,255,20,.15);
    border-radius:12px; padding:8px; z-index:2000;
    box-shadow:0 8px 32px rgba(0,0,0,.6), 0 0 20px rgba(57,255,20,.08);
    opacity:0; pointer-events:none; transform:translateY(-6px);
    transition:opacity .18s, transform .18s;
}
.nav-user-dropdown.open { opacity:1; pointer-events:all; transform:none; }

.nud-header { display:flex; align-items:center; gap:10px; padding:8px 6px 10px; }
.nud-avatar { flex-shrink:0; }
.nud-name { font-size:.82rem; font-weight:700; color:#fff; }
.nud-email { font-size:.7rem; color:rgba(255,255,255,.4); margin-top:1px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:130px; }
.nud-badge-admin { display:inline-block; font-size:.65rem; background:rgba(255,215,0,.1); color:#ffd700; border:1px solid rgba(255,215,0,.3); border-radius:10px; padding:1px 6px; margin-top:3px; }
.nud-sep { border:none; border-top:1px solid rgba(255,255,255,.06); margin:4px 0; }
.nud-item {
    display:flex; align-items:center; gap:8px;
    padding:8px 10px; border-radius:8px; font-size:.82rem; color:rgba(255,255,255,.65);
    transition:background .15s, color .15s; width:100%; text-align:left; cursor:pointer;
    background:none; border:none; font-family:inherit; text-decoration:none;
}
.nud-item:hover { background:rgba(255,255,255,.06); color:#fff; }
.nud-admin { color:var(--green) !important; }
.nud-admin:hover { background:rgba(57,255,20,.08) !important; }
.nud-logout { color:#ff6b6b !important; }
.nud-logout:hover { background:rgba(255,77,77,.08) !important; }

/* ── Login page ───────────────────────────────────────────────── */
.auth-wrap {
    min-height:100vh; display:flex; align-items:center; justify-content:center;
    padding:calc(var(--nav-h) + 30px) 20px 40px;
    background:radial-gradient(ellipse at 30% 50%, rgba(57,255,20,.05) 0%, transparent 60%);
    position:relative; z-index:1;
}
.auth-card {
    width:100%; max-width:400px; padding:36px 32px;
    background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:var(--radius);
    backdrop-filter:blur(16px);
}
.auth-logo { text-align:center; margin-bottom:24px; }
.auth-logo img { width:56px; height:56px; object-fit:contain; margin:0 auto; filter:drop-shadow(0 0 12px rgba(57,255,20,.4)); }
.auth-logo h1 { font-size:1.25rem; font-weight:700; margin-top:10px; }
.auth-logo p  { font-size:.78rem; color:rgba(255,255,255,.35); margin-top:3px; }
.auth-tabs { display:flex; background:rgba(255,255,255,.04); border-radius:8px; padding:3px; margin-bottom:20px; }
.auth-tab { flex:1; padding:7px; border:none; background:none; color:rgba(255,255,255,.4); font-family:inherit; font-size:.81rem; font-weight:600; border-radius:6px; cursor:pointer; transition:background .15s, color .15s; }
.auth-tab.active { background:rgba(57,255,20,.1); color:var(--green); }
.auth-form { display:none; flex-direction:column; gap:11px; }
.auth-form.active { display:flex; }
.auth-inp-wrap { position:relative; }
.auth-inp-wrap i.ii { position:absolute; left:11px; top:50%; transform:translateY(-50%); color:rgba(255,255,255,.3); font-size:1rem; pointer-events:none; }
.auth-inp {
    width:100%; padding:10px 12px 10px 36px;
    background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
    border-radius:8px; color:#fff; font-size:.84rem; outline:none; font-family:inherit;
    transition:border-color .18s;
}
.auth-inp:focus { border-color:rgba(57,255,20,.45); }
.auth-inp::placeholder { color:rgba(255,255,255,.22); }
.auth-pt { position:absolute; right:10px; top:50%; transform:translateY(-50%); color:rgba(255,255,255,.3); cursor:pointer; font-size:1rem; background:none; border:none; padding:0; transition:color .15s; }
.auth-pt:hover { color:rgba(255,255,255,.6); }
.auth-btn { width:100%; padding:11px; background:var(--green); color:#000; font-family:inherit; font-weight:700; font-size:.87rem; border:none; border-radius:8px; cursor:pointer; display:flex; align-items:center; justify-content:center; gap:8px; transition:filter .18s; box-shadow:0 0 20px rgba(57,255,20,.3); margin-top:4px; }
.auth-btn:hover { filter:brightness(1.1); }
.auth-btn:disabled { opacity:.6; cursor:not-allowed; }
.auth-msg { padding:9px 13px; border-radius:8px; font-size:.8rem; }
.auth-msg.ok  { background:rgba(57,255,20,.08); border:1px solid rgba(57,255,20,.25); color:var(--green); }
.auth-msg.err { background:rgba(255,77,77,.08);  border:1px solid rgba(255,77,77,.25);  color:#ff6b6b; }
.auth-msg.hidden { display:none; }
.auth-spin { width:15px; height:15px; border:2px solid rgba(0,0,0,.25); border-top-color:#000; border-radius:50%; animation:spinA .55s linear infinite; display:inline-block; }
@keyframes spinA { to { transform:rotate(360deg); } }

/* ── Perfil page ───────────────────────────────────────────────── */
.perfil-wrap {
    max-width:900px; margin:0 auto; padding:calc(var(--nav-h) + 32px) 24px 60px;
    position:relative; z-index:1;
}
.perfil-header { margin-bottom:28px; }
.perfil-header h1 { font-size:1.4rem; font-weight:700; display:flex; align-items:center; gap:9px; }
.perfil-header h1 i { color:var(--green); }
.perfil-grid { display:grid; grid-template-columns:280px 1fr; gap:20px; }
@media(max-width:820px) { .perfil-grid { grid-template-columns:1fr; } }

.perfil-card {
    padding:24px 20px; text-align:center;
    background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:var(--radius);
}
.pav-wrap { position:relative; display:inline-block; margin-bottom:14px; }
.pav-big {
    width:100px; height:100px; border-radius:50%;
    background:rgba(57,255,20,.1); border:3px solid rgba(57,255,20,.3);
    display:flex; align-items:center; justify-content:center;
    font-size:2.5rem; overflow:hidden; margin:0 auto;
}
.pav-big img { width:100%; height:100%; object-fit:cover; }
.pav-edit-btn {
    position:absolute; bottom:2px; right:2px;
    width:28px; height:28px; border-radius:50%;
    background:var(--green); color:#000; border:none;
    display:flex; align-items:center; justify-content:center;
    font-size:.82rem; cursor:pointer; box-shadow:0 2px 8px rgba(0,0,0,.5);
    transition:filter .15s;
}
.pav-edit-btn:hover { filter:brightness(1.1); }
.pn-name  { font-size:1.05rem; font-weight:700; }
.pn-user  { font-size:.78rem; color:rgba(255,255,255,.4); margin-top:2px; }
.pn-bio   { font-size:.79rem; color:rgba(255,255,255,.5); margin-top:9px; line-height:1.6; }
.pn-since { font-size:.7rem; color:rgba(255,255,255,.3); margin-top:7px; }
.pstats { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; margin-top:14px; }
.pstat { background:rgba(57,255,20,.06); border:1px solid rgba(57,255,20,.15); border-radius:9px; padding:9px 6px; text-align:center; }
.pstat-n { font-size:1.1rem; font-weight:700; color:var(--green); }
.pstat-l { font-size:.62rem; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.04em; margin-top:2px; }

.perfil-edit { background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:var(--radius); padding:24px; }
.pe-title { font-size:.88rem; font-weight:700; color:var(--green); margin-bottom:16px; display:flex; align-items:center; gap:7px; }
.pe-form { display:flex; flex-direction:column; gap:13px; }
.pe-group { display:flex; flex-direction:column; gap:5px; }
.pe-group label { font-size:.72rem; font-weight:700; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.05em; }
.pe-inp, .pe-ta {
    width:100%; padding:9px 13px;
    background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
    border-radius:8px; color:#fff; font-size:.84rem; outline:none; font-family:inherit;
    transition:border-color .18s;
}
.pe-inp:focus, .pe-ta:focus { border-color:rgba(57,255,20,.4); }
.pe-inp::placeholder, .pe-ta::placeholder { color:rgba(255,255,255,.22); }
.pe-ta { resize:vertical; min-height:76px; line-height:1.5; }
.pe-cc { font-size:.68rem; color:rgba(255,255,255,.3); text-align:right; margin-top:-3px; }
.pe-sep { border:none; border-top:1px solid rgba(255,255,255,.06); margin:4px 0; }
.pe-msg { padding:9px 13px; border-radius:8px; font-size:.8rem; }
.pe-msg.ok  { background:rgba(57,255,20,.08); border:1px solid rgba(57,255,20,.25); color:var(--green); }
.pe-msg.err { background:rgba(255,77,77,.08); border:1px solid rgba(255,77,77,.25); color:#ff6b6b; }
.pe-msg.hidden { display:none; }

/* Modal avatar */
.modal-overlay {
    position:fixed; inset:0; z-index:3000; background:rgba(0,0,0,.75);
    backdrop-filter:blur(5px); display:flex; align-items:center; justify-content:center;
    padding:20px; opacity:0; pointer-events:none; transition:opacity .22s;
}
.modal-overlay.open { opacity:1; pointer-events:all; }
.modal-box {
    width:100%; max-width:420px; padding:28px 26px;
    background:#111; border:1px solid rgba(57,255,20,.2); border-radius:var(--radius);
    position:relative; transform:translateY(16px); transition:transform .25s;
}
.modal-overlay.open .modal-box { transform:none; }
.modal-close { position:absolute; top:10px; right:10px; width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; background:rgba(255,255,255,.06); color:rgba(255,255,255,.5); font-size:1rem; cursor:pointer; border:none; transition:background .15s; }
.modal-close:hover { background:rgba(255,255,255,.12); color:#fff; }

/* ── Toast ───────────────────────────────────────────────────── */
#web-toasts { position:fixed; bottom:18px; right:18px; z-index:9999; display:flex; flex-direction:column; gap:8px; pointer-events:none; }
.web-toast { display:flex; align-items:center; gap:9px; background:rgba(8,8,8,.97); border:1px solid rgba(57,255,20,.2); border-radius:10px; padding:11px 15px; box-shadow:0 0 16px rgba(57,255,20,.15); animation:wtin .28s ease, wtout .28s ease 3.7s forwards; min-width:180px; max-width:280px; font-size:.82rem; }
.web-toast i { color:var(--green); font-size:1.05rem; flex-shrink:0; }
@keyframes wtin  { from{opacity:0;transform:translateX(24px)} to{opacity:1;transform:none} }
@keyframes wtout { from{opacity:1} to{opacity:0;transform:translateX(24px)} }

/* ── Admin page ──────────────────────────────────────────────── */
.admin-wrap {
    max-width:1100px; margin:0 auto;
    padding:calc(var(--nav-h) + 32px) 24px 60px;
    position:relative; z-index:1;
}
.admin-page-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:26px; flex-wrap:wrap; gap:12px; }
.admin-page-header h1 { font-size:1.35rem; font-weight:700; display:flex; align-items:center; gap:9px; }
.admin-page-header h1 i { color:var(--green); }
.admin-badge { display:inline-block; padding:3px 10px; border-radius:20px; font-size:.7rem; font-weight:700; background:rgba(255,215,0,.1); color:#ffd700; border:1px solid rgba(255,215,0,.3); }

.admin-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:24px; }
@media(max-width:640px) { .admin-stats { grid-template-columns:repeat(2,1fr); } }
.astat { padding:18px; background:var(--glass-bg); border:1px solid var(--glass-border); border-radius:var(--radius-sm); text-align:center; transition:border-color .2s; }
.astat:hover { border-color:rgba(57,255,20,.25); }
.astat i { font-size:1.8rem; color:var(--green); margin-bottom:7px; }
.astat-n { font-size:1.5rem; font-weight:700; color:var(--green); }
.astat-l { font-size:.71rem; color:rgba(255,255,255,.4); margin-top:2px; }

.admin-tabs { display:flex; gap:0; background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06); border-radius:9px; padding:3px; margin-bottom:20px; width:fit-content; flex-wrap:wrap; }
.admin-tab { padding:7px 18px; border-radius:7px; font-size:.82rem; font-weight:500; color:rgba(255,255,255,.4); transition:background .15s, color .15s; cursor:pointer; border:none; font-family:inherit; background:none; }
.admin-tab.active { background:rgba(57,255,20,.1); color:var(--green); }

.admin-panel { display:none; }
.admin-panel.active { display:block; }

.admin-panel-header { display:flex; justify-content:flex-end; margin-bottom:14px; }

.admin-table-wrap { overflow-x:auto; }
.admin-table { width:100%; border-collapse:collapse; font-size:.82rem; }
.admin-table th { background:rgba(57,255,20,.07); color:var(--green); font-weight:600; padding:9px 12px; text-align:left; border-bottom:1px solid rgba(57,255,20,.15); white-space:nowrap; }
.admin-table td { padding:9px 12px; border-bottom:1px solid rgba(255,255,255,.04); color:rgba(255,255,255,.6); }
.admin-table tr:hover td { background:rgba(255,255,255,.02); }
.admin-table td strong { color:#fff; }

.badge-active   { display:inline-block; padding:2px 8px; border-radius:20px; font-size:.67rem; font-weight:700; background:rgba(57,255,20,.1); color:var(--green); border:1px solid rgba(57,255,20,.25); }
.badge-inactive { display:inline-block; padding:2px 8px; border-radius:20px; font-size:.67rem; font-weight:700; background:rgba(255,77,77,.1); color:#ff6b6b; border:1px solid rgba(255,77,77,.25); }
.badge-admin    { display:inline-block; padding:2px 8px; border-radius:20px; font-size:.67rem; font-weight:700; background:rgba(255,215,0,.1); color:#ffd700; border:1px solid rgba(255,215,0,.3); }
.badge-user     { display:inline-block; padding:2px 8px; border-radius:20px; font-size:.67rem; font-weight:700; background:rgba(255,255,255,.07); color:rgba(255,255,255,.5); border:1px solid rgba(255,255,255,.1); }

.tbl-actions { display:flex; gap:6px; }
.btn-tbl-edit { display:inline-flex; align-items:center; gap:4px; padding:5px 10px; border:1px solid rgba(57,255,20,.25); color:var(--green); border-radius:6px; font-size:.76rem; cursor:pointer; background:none; font-family:inherit; transition:background .15s; }
.btn-tbl-edit:hover { background:rgba(57,255,20,.07); }
.btn-tbl-del  { display:inline-flex; align-items:center; gap:4px; padding:5px 10px; border:1px solid rgba(255,77,77,.25); color:#ff6b6b; border-radius:6px; font-size:.76rem; cursor:pointer; background:none; font-family:inherit; transition:background .15s; }
.btn-tbl-del:hover { background:rgba(255,77,77,.07); }

/* Admin modal forms */
.aform { display:flex; flex-direction:column; gap:12px; margin-top:16px; }
.aform-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.agroup { display:flex; flex-direction:column; gap:5px; }
.agroup label { font-size:.72rem; font-weight:700; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:.05em; }
.ainp, .ata, .asel {
    width:100%; padding:9px 13px;
    background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08);
    border-radius:8px; color:#fff; font-size:.84rem; outline:none; font-family:inherit;
    transition:border-color .18s;
}
.ainp:focus, .ata:focus, .asel:focus { border-color:rgba(57,255,20,.4); }
.ainp::placeholder, .ata::placeholder { color:rgba(255,255,255,.22); }
.ata { resize:vertical; min-height:72px; line-height:1.5; }
.asel { cursor:pointer; }
.asel option { background:#111; color:#fff; }
.amsg { padding:8px 12px; border-radius:7px; font-size:.79rem; }
.amsg.ok  { background:rgba(57,255,20,.08); border:1px solid rgba(57,255,20,.25); color:var(--green); }
.amsg.err { background:rgba(255,77,77,.08); border:1px solid rgba(255,77,77,.25); color:#ff6b6b; }
.amsg.hidden { display:none; }
.amodal-footer { display:flex; justify-content:flex-end; gap:10px; margin-top:14px; }

/* Confirm dialog */
.confirm-wrap { max-width:320px; }
.confirm-wrap h3 { font-size:.95rem; font-weight:700; margin-bottom:8px; }
.confirm-wrap p  { font-size:.82rem; color:rgba(255,255,255,.5); margin-bottom:18px; }
.confirm-btns { display:flex; gap:10px; justify-content:flex-end; }

/* Responsive admin */
@media(max-width:640px) { .aform-row { grid-template-columns:1fr; } }

/* ── Game card icon (emoji) ──────────────────────────────────── */
.game-card-icon {
    font-size: 2.2rem;
    line-height: 1;
    flex-shrink: 0;
    filter: drop-shadow(0 0 8px rgba(57,255,20,0.3));
}
.game-card-header {
    gap: 12px;
    align-items: center;
}
.game-card-header > div { min-width: 0; }
