/* ═══════════════════════════════════════════════
   WordMaze — 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:340px;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:500px;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); }

.word-list { display:flex;flex-wrap:wrap;gap:8px;justify-content:center;padding:0 0 14px;width:100%; }
.word-tag { padding:6px 14px;border-radius:var(--radius-pill);font-size:12px;font-weight:600;letter-spacing:1.5px;color:var(--navy);background:var(--bg-subtle);border:1.5px solid var(--border);transition:all .15s; }
.word-tag--found { background:var(--teal);color:var(--white);border-color:var(--teal);text-decoration:line-through; }

.wm-grid-wrap { display:flex;justify-content:center;width:100%;padding:4px 0; }
.wm-grid { display:grid;gap:4px; }
.wm-cell { aspect-ratio:1;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:clamp(16px,4.5vw,22px);font-weight:700;color:var(--navy);background:var(--bg-surface);cursor:pointer;transition:all .12s;user-select:none; }
.wm-cell--selected { background:var(--sky);color:var(--white); }
.wm-cell--found { background:var(--teal);color:var(--white); }
.wm-cell--wrong { background:var(--error);color:var(--white);animation:shake .35s ease; }

.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;transition:color var(--transition); }
.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:4px; }
.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 fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
@keyframes pop{0%{transform:scale(.85);opacity:0}60%{transform:scale(1.05)}100%{transform:scale(1);opacity:1}}
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-4px)}40%{transform:translateX(4px)}60%{transform:translateX(-3px)}80%{transform:translateX(2px)}}
