/* ==========================================================================
   TechBiz Security — games.css (Phase 5)
   ========================================================================== */

.game-launch { text-align: left; cursor: pointer; border: 1px solid var(--border); font: inherit; color: inherit; width: 100%; }

/* Achievements */
.achievements { margin-top: var(--space-5); }
.achievements h3 { margin-bottom: var(--space-2); }
.achievements h3 i { color: #e6a52f; }
.achievements__row { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.achievements__empty { color: var(--text-secondary); font-size: 0.9rem; }
.badge-medal {
    display: flex; align-items: center; gap: 0.6rem;
    padding: 0.6rem 1rem; border-radius: 999px;
    background: color-mix(in srgb, var(--accent) 12%, transparent);
    border: 1px solid var(--border-strong);
}
.badge-medal i { color: #e6a52f; font-size: 1.1rem; }
.badge-medal span { font-size: 0.85rem; font-weight: 600; }

/* Stage / panels */
.game-back { margin-bottom: var(--space-3); }
.game-panel__title { margin-bottom: var(--space-3); }
.game-hud { display: flex; gap: var(--space-4); flex-wrap: wrap; font-family: var(--font-head); font-size: 0.9rem; margin-bottom: var(--space-3); }
.game-hud strong { color: var(--accent); }
.game-controls { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-top: var(--space-3); }

/* Password meter */
.pw-meter { height: 10px; background: var(--bg); border-radius: 999px; overflow: hidden; margin: var(--space-2) 0; }
.pw-meter__bar { height: 100%; width: 0; border-radius: 999px; transition: width .25s, background .25s; }
.pw-verdict { font-family: var(--font-head); font-weight: 700; }
.pw-criteria { display: grid; gap: 0.4rem; margin-top: var(--space-2); }
.pw-criteria li { font-size: 0.88rem; color: var(--text-secondary); }
.pw-criteria li i { color: var(--text-secondary); margin-right: 0.4rem; }
.pw-criteria li.is-met { color: var(--text); }
.pw-criteria li.is-met i { color: var(--accent); }
.pw-entropy { margin-top: var(--space-2); font-size: 0.82rem; color: var(--accent-2); }

/* Quiz */
.qz-q { font-size: 1.1rem; margin-bottom: var(--space-3); }
.qz-opts { display: grid; gap: 0.6rem; }
.qz-opt {
    text-align: left; padding: 0.8rem 1rem; border: 1px solid var(--border);
    border-radius: var(--radius-sm); background: var(--bg-secondary); color: var(--text);
    cursor: pointer; font: inherit; transition: border-color .2s;
}
.qz-opt:hover:not(:disabled) { border-color: var(--accent); }
.qz-opt.is-correct { border-color: var(--accent); background: color-mix(in srgb, var(--accent) 14%, transparent); }
.qz-opt.is-wrong { border-color: var(--danger); background: color-mix(in srgb, var(--danger) 12%, transparent); }

/* SOC */
.soc-alert { text-align: center; min-height: 120px; display: grid; place-content: center; gap: 0.6rem; }
.soc-alert__icon { font-size: 1.8rem; color: #e6a52f; }
.soc-alert p { color: var(--text); font-size: 1.05rem; }

/* Network defense */
#ndCanvas { width: 100%; max-width: 640px; height: auto; border: 1px solid var(--border-strong); border-radius: var(--radius-sm); background: #05070b; margin-top: var(--space-2); cursor: crosshair; display: block; }
#blCanvas { width: 100%; max-width: 640px; height: auto; border: 1px solid var(--border-strong); border-radius: var(--radius-sm); background: #05070b; margin-top: var(--space-2); cursor: none; display: block; touch-action: none; }
#ddCanvas { width: 100%; max-width: 640px; height: auto; border: 1px solid var(--border-strong); border-radius: var(--radius-sm); background: #05070b; margin-top: var(--space-2); cursor: crosshair; display: block; }

/* Modal */
.game-modal { position: fixed; inset: 0; z-index: 9998; display: grid; place-items: center; background: rgba(5,7,11,0.85); backdrop-filter: blur(8px); padding: var(--space-3); }
.game-modal__inner { max-width: 440px; width: 100%; }
.game-modal__inner h3 { margin-bottom: 0.4rem; }
.leaderboard { margin-top: var(--space-3); }
.leaderboard h4 { margin-bottom: var(--space-2); }
.leaderboard ol { list-style: decimal inside; }
.leaderboard li { display: flex; justify-content: space-between; padding: 0.4rem 0; border-bottom: 1px solid var(--border); font-size: 0.9rem; }
.leaderboard li strong { color: var(--accent); }
