/* ═══════════════════════════════════════════════
   LogicGrid — Game Styles
   ═══════════════════════════════════════════════ */

.menu { display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:18px; }
.menu-title { font-size:clamp(38px,10vw,56px);font-weight:700;letter-spacing:4px;color:var(--navy); }
.menu-sub { font-size:14px;font-weight:300;color:var(--text-dim);letter-spacing:1.5px; }
.menu-how { max-width:360px;text-align:center;font-size:13px;font-weight:400;line-height:1.7;color:var(--text-mid);padding:16px 20px;border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border); }
.diff-btns { display:flex;flex-wrap:wrap;gap:10px;margin-top:4px;justify-content:center; }
.diff-btn { padding:14px 24px;border-radius:var(--radius-md);border:2px solid var(--border);background:var(--bg);color:var(--navy);font-size:13px;font-weight:600;letter-spacing:2.5px;cursor:pointer;font-family:var(--font);transition:all var(--transition);box-shadow:var(--shadow-sm); }
.diff-btn:hover { background:var(--bg-subtle);transform:translateY(-2px);box-shadow:var(--shadow-md); }

.game { display:none;flex-direction:column;align-items:center;width:100%;max-width:560px;flex:1; }
.game.active { display:flex; }

.game-hdr { display:flex;justify-content:space-between;align-items:center;width:100%;padding:0 0 10px; }
.badge { background:var(--bg-subtle);border:1.5px solid var(--border);padding:8px 16px;border-radius:var(--radius-pill);font-size:11px;font-weight:600;letter-spacing:2.5px;color:var(--navy); }

.clues-box { width:100%;padding:12px 16px;margin-bottom:14px;border-radius:var(--radius-md);background:var(--bg-subtle);border:1px solid var(--border); }
.clues-title { font-size:11px;font-weight:600;letter-spacing:2px;color:var(--text-dim);margin-bottom:8px; }
.clue-item { font-size:13px;font-weight:400;line-height:1.65;color:var(--text-mid);padding:2px 0; }
.clue-num { font-weight:600;color:var(--navy);margin-right:4px; }

.lg-grid-wrap { width:100%;overflow-x:auto;padding:4px 0 12px; }
.lg-grid { border-collapse:collapse;margin:0 auto; }
.lg-grid th { font-size:11px;font-weight:600;letter-spacing:.5px;color:var(--navy);padding:6px 8px;text-align:center;white-space:nowrap; }
.lg-grid th.lg-row-hdr { text-align:right;padding-right:10px; }
.lg-grid td { width:42px;height:42px;text-align:center;vertical-align:middle;border:1.5px solid var(--border);cursor:pointer;font-size:16px;font-weight:700;color:var(--navy);transition:all .1s;user-select:none;border-radius:3px; }
.lg-grid td:hover { background:var(--bg-surface); }
.lg-grid td.lg-yes { background:var(--teal);color:var(--white); }
.lg-grid td.lg-no { background:rgba(45,50,112,.04);color:rgba(45,50,112,.25); }
.lg-grid td.lg-maybe { background:var(--bg-subtle);color:var(--sky); }
.lg-grid .lg-sep { border-right:3px solid var(--navy); }

.game-footer { display:flex;gap:18px;padding:14px 0 4px; }
.foot-btn { background:none;border:none;color:var(--text-mid);font-size:16px;font-weight:600;cursor:pointer;font-family:var(--font);padding:10px 14px; }
.foot-btn:hover { color:var(--navy); }

.win-card { background:var(--bg);border-radius:var(--radius-lg);padding:40px 48px;text-align:center;border:1.5px solid var(--border);box-shadow:0 12px 40px rgba(45,50,112,.12);animation:pop .45s ease; }
.win-check { width:68px;height:68px;border-radius:50%;margin:0 auto 16px;background:rgba(80,194,195,.15);border:3px solid var(--teal);display:flex;align-items:center;justify-content:center;font-size:30px;font-weight:700;color:var(--teal); }
.win-title { font-size:28px;font-weight:700;letter-spacing:4px;color:var(--navy);margin-bottom:16px; }
.win-btn { display:block;width:100%;padding:14px 0;border-radius:var(--radius-md);border:none;background:var(--navy);color:var(--white);font-size:13px;font-weight:700;letter-spacing:2px;cursor:pointer;font-family:var(--font);margin-bottom:8px; }
.win-btn--sec { background:var(--bg);border:1.5px solid var(--border);color:var(--text-dim);font-size:12px; }

@keyframes pop{0%{transform:scale(.85);opacity:0}60%{transform:scale(1.05)}100%{transform:scale(1);opacity:1}}
