/* ═══════════════════════════════════════════════
   КРИПТОГРАММА  ·  Modern Dark UI
   Space Grotesk + Space Mono · Glassmorphism
   ═══════════════════════════════════════════════ */

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

/* ── Tokens ─────────────────────────────────── */
:root {
  --bg:            #06071a;
  --glass:         rgba(255,255,255,0.042);
  --glass-b:       rgba(255,255,255,0.08);
  --glass-h:       rgba(255,255,255,0.07);

  --text:          #eef0ff;
  --text-2:        #7880a8;
  --text-3:        #252a48;

  --accent:        #6c8eff;
  --accent-2:      #a78bfa;
  --accent-s:      rgba(108,142,255,0.13);
  --accent-g:      rgba(108,142,255,0.3);
  --accent-b:      rgba(108,142,255,0.28);

  --green:         #2dd4a0;
  --green-s:       rgba(45,212,160,0.11);
  --green-b:       rgba(45,212,160,0.32);

  --red:           #ff6b8a;
  --red-s:         rgba(255,107,138,0.11);
  --red-b:         rgba(255,107,138,0.32);

  --amber:         #f9c74f;
  --amber-s:       rgba(249,199,79,0.11);
  --amber-b:       rgba(249,199,79,0.32);

  --cell-bg:       rgba(9,11,30,0.94);
  --cell-b:        rgba(255,255,255,0.07);
  --key-bg:        rgba(16,20,50,0.97);
  --key-b:         rgba(255,255,255,0.09);
  --key-text:      #bcc0dc;

  --sh-sm:  0 1px 4px rgba(0,0,0,0.5);
  --sh-md:  0 4px 20px rgba(0,0,0,0.55);
  --sh-lg:  0 16px 48px rgba(0,0,0,0.65);
  --sh-acc: 0 4px 24px rgba(108,142,255,0.32);
  --sh-grn: 0 4px 20px rgba(45,212,160,0.22);
  --sh-key: 0 3px 0 rgba(0,0,0,0.6), inset 0 1px 0 rgba(255,255,255,0.07);

  --r-xs: 6px;  --r-sm: 10px;
  --r-md: 14px; --r-lg: 20px;
  --r-xl: 26px; --r-p:  999px;
}

body.light {
  --bg:      #edf0ff;
  --glass:   rgba(255,255,255,0.74);
  --glass-b: rgba(80,100,210,0.12);
  --glass-h: rgba(255,255,255,0.88);
  --text:    #0c0f28;
  --text-2:  #525880;
  --text-3:  #b8bdd8;
  --accent:  #3d5de0;  --accent-2: #7c3aed;
  --accent-s: rgba(61,93,224,0.09);
  --accent-g: rgba(61,93,224,0.22);
  --accent-b: rgba(61,93,224,0.25);
  --green:   #0ba878;
  --green-s: rgba(11,168,120,0.08);
  --green-b: rgba(11,168,120,0.28);
  --red:     #e03060;
  --red-s:   rgba(224,48,96,0.08);
  --red-b:   rgba(224,48,96,0.28);
  --amber:   #c07800;
  --amber-s: rgba(192,120,0,0.09);
  --amber-b: rgba(192,120,0,0.28);
  --cell-bg: #ffffff;
  --cell-b:  rgba(80,100,210,0.1);
  --key-bg:  #ffffff;
  --key-b:   rgba(80,100,210,0.14);
  --key-text: #161a38;
  --sh-sm:   0 1px 4px rgba(0,0,40,0.1);
  --sh-md:   0 4px 16px rgba(0,0,40,0.12);
  --sh-lg:   0 12px 40px rgba(0,0,40,0.14);
  --sh-key:  0 3px 0 rgba(0,0,40,0.12), inset 0 1px 0 rgba(255,255,255,0.95);
}

/* ── Reset ──────────────────────────────────── */
*,*::before,*::after { box-sizing:border-box; -webkit-tap-highlight-color:transparent; }
html,body {
  margin:0; padding:0; height:100%; overflow:hidden;
  font-family:'Space Grotesk',system-ui,sans-serif;
  background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased;
  /* touch-action глобально zoom алдын алу */
  touch-action: pan-x pan-y;
}
button { font-family:inherit; }

/* ── Keyframes ──────────────────────────────── */
@keyframes shake {
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-6px)} 40%{transform:translateX(6px)}
  60%{transform:translateX(-3px)} 80%{transform:translateX(3px)}
}
@keyframes pop {
  0%{transform:scale(1)} 45%{transform:scale(1.22)} 100%{transform:scale(1)}
}
@keyframes fadeIn  { from{opacity:0} to{opacity:1} }
@keyframes cardIn  { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
@keyframes modalIn {
  from { opacity:0; transform:scale(0.9); }
  to   { opacity:1; transform:scale(1); }
}
@keyframes shimmer {
  0%  {background-position:-200% center}
  100%{background-position: 200% center}
}
@keyframes float {
  0%,100%{transform:translateY(0)} 50%{transform:translateY(-7px)}
}
@keyframes pulseRing {
  0%  {box-shadow:0 0 0 0 var(--accent-g), var(--sh-key)}
  70% {box-shadow:0 0 0 7px transparent, var(--sh-key)}
  100%{box-shadow:0 0 0 0 transparent, var(--sh-key)}
}

.shake { animation:shake .36s cubic-bezier(.36,.07,.19,.97) both }
.pop   { animation:pop   .3s  cubic-bezier(.34,1.56,.64,1)  both }

/* ── Layout ─────────────────────────────────── */
#app,.app { height:100dvh; min-height:100dvh; }
.screen {
  height:100dvh; display:flex; flex-direction:column;
  position:relative; z-index:1; overflow:hidden;
}
.center-screen {
  align-items:center; justify-content:center;
  padding:20px; overflow-y:auto;
}

/* ── Orbs ───────────────────────────────────── */
.orb { position:fixed; border-radius:50%; pointer-events:none; z-index:0; }
.orb-1 {
  top:-18%; left:-12%; width:62vw; height:62vw;
  background:radial-gradient(circle, rgba(108,142,255,0.13) 0%, transparent 68%);
  filter:blur(30px); animation:float 9s ease-in-out infinite;
}
.orb-2 {
  bottom:-12%; right:-14%; width:58vw; height:58vw;
  background:radial-gradient(circle, rgba(167,139,250,0.1) 0%, transparent 68%);
  filter:blur(30px); animation:float 11s ease-in-out infinite reverse;
}

/* ── Glass card (menu/settings) ─────────────── */
.card {
  width:100%; max-width:400px;
  background:var(--glass); border:1px solid var(--glass-b);
  border-radius:var(--r-xl); padding:28px 24px;
  backdrop-filter:blur(28px) saturate(1.5);
  -webkit-backdrop-filter:blur(28px) saturate(1.5);
  box-shadow:var(--sh-lg), inset 0 1px 0 rgba(255,255,255,0.09);
  animation:cardIn .4s cubic-bezier(.25,.8,.25,1) both;
  position:relative; overflow:hidden;
}
.card::before {
  content:''; position:absolute; top:0; left:12%; right:12%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.18),transparent);
}

/* ── Menu ───────────────────────────────────── */
.logo {
  font-size:54px; margin-bottom:16px; display:block;
  animation:float 5s ease-in-out infinite;
  filter:drop-shadow(0 6px 18px rgba(108,142,255,0.45));
}
.title-xl {
  font-family:'Space Mono',monospace;
  font-size:24px; font-weight:700; letter-spacing:5px;
  text-transform:uppercase; margin:0 0 8px;
  background:linear-gradient(130deg, var(--text) 30%, var(--accent));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.subtitle { font-size:13px; color:var(--text-2); line-height:1.7; }

/* ── Buttons ────────────────────────────────── */
.menu-buttons,.settings-list {
  display:flex; flex-direction:column; gap:10px; margin-top:6px;
}
.btn {
  border:none; border-radius:var(--r-md);
  padding:15px 20px; cursor:pointer;
  font-weight:600; font-size:14px; letter-spacing:0.1px;
  transition:transform .15s cubic-bezier(.34,1.4,.64,1), box-shadow .15s ease;
  display:flex; align-items:center; justify-content:center; gap:8px;
  position:relative; overflow:hidden;
}
.btn:disabled { opacity:.38; cursor:default; }
.btn-primary {
  background:linear-gradient(135deg,var(--accent) 0%,var(--accent-2) 100%);
  color:#fff; box-shadow:var(--sh-acc); font-weight:700;
}
.btn-primary:hover:not(:disabled) { transform:translateY(-2px); box-shadow:0 8px 30px rgba(108,142,255,.42); }
.btn-primary:active:not(:disabled){ transform:scale(.97); }
.btn-soft {
  background:var(--glass); border:1px solid var(--glass-b);
  color:var(--text-2); backdrop-filter:blur(8px);
}
.btn-soft:hover:not(:disabled)  { background:var(--glass-h); color:var(--text); border-color:var(--accent-b); transform:translateY(-1px); }
.btn-soft:active:not(:disabled) { transform:scale(.97); }
.btn-success {
  background:var(--green-s); border:1px solid var(--green-b);
  color:var(--green); font-weight:700; box-shadow:var(--sh-grn);
}
.btn-success:hover:not(:disabled)  { transform:translateY(-1px); }
.btn-success:active:not(:disabled) { transform:scale(.97); }
.btn-danger-soft {
  background:var(--red-s); border:1px solid var(--red-b); color:var(--red);
}
.btn-danger-soft:hover:not(:disabled)  { transform:translateY(-1px); }
.btn-danger-soft:active:not(:disabled) { transform:scale(.97); }

.small-note { display:block; font-size:11px; margin-top:3px; opacity:.6; font-weight:400; }

/* ── Utility ────────────────────────────────── */
.row           { display:flex; align-items:center; }
.space-between { justify-content:space-between; }
.center        { justify-content:center; }

/* ─────────────────────────────────────────────
   TOPBAR  (жаңа дизайн)
   ───────────────────────────────────────────── */
.topbar {
  flex-shrink:0;
  padding:10px 14px 8px;
  border-bottom:1px solid var(--glass-b);
  background:rgba(6,7,26,0.76);
  backdrop-filter:blur(28px) saturate(1.5);
  -webkit-backdrop-filter:blur(28px) saturate(1.5);
  position:relative; z-index:3;
}
body.light .topbar { background:rgba(237,240,255,0.84); }

.topbar-inner {
  width:100%; max-width:560px; margin:0 auto;
  display:flex; flex-direction:column; gap:7px;
}

/* Жол 1: артқа · деңгей нүктелері (орта) · ұпай */
.tbar-row1 {
  display:flex;
  align-items:center;
  justify-content:space-between;
  position:relative;
  min-height:34px;
}

.tbar-back {
  width:34px; height:34px;
  border-radius:var(--r-sm);
  border:1px solid var(--glass-b);
  background:var(--glass);
  color:var(--text-2); cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  backdrop-filter:blur(8px);
  transition:all .15s ease;
  flex-shrink:0; position:relative; z-index:1;
}
.tbar-back:hover  { background:var(--glass-h); color:var(--text); border-color:var(--accent-b); transform:translateX(-1px); }
.tbar-back:active { transform:scale(.9); }

/* Нақты орта — absolute left:0 right:0 */
.tbar-level {
  position:absolute; left:0; right:0;
  display:flex; flex-direction:column; align-items:center; gap:3px;
  pointer-events:none;
}
.level-dots {
  display:flex; flex-wrap:wrap;
  gap:3px; justify-content:center;
  max-width:200px;
}
.lvl-dot {
  width:5px; height:5px; border-radius:50%;
  background:var(--text-3);
  transition:background .25s, transform .25s;
}
.lvl-dot.done   { background:var(--accent-2); opacity:.45; }
.lvl-dot.active { background:var(--accent); transform:scale(1.55); box-shadow:0 0 7px var(--accent-g); }

.level-label {
  font-family:'Space Mono',monospace;
  font-size:9px; font-weight:700;
  color:var(--text-3); letter-spacing:1px;
}

.tbar-score {
  display:flex; align-items:center; justify-content:flex-end;
  gap:4px; flex-shrink:0; position:relative; z-index:1;
}
.score-num {
  font-family:'Space Mono',monospace;
  font-size:13px; font-weight:700; color:var(--amber);
}

/* Жол 2: таймер · жүректер · прогресс */
.tbar-row2 {
  display:grid;
  grid-template-columns:80px 1fr 60px;
  align-items:center;
  gap:4px;
}

.tbar-stat {
  display:flex; align-items:center; gap:5px;
  color:var(--text-2);
}
.tbar-stat-right { justify-content:flex-end; }
.tbar-stat-val {
  font-family:'Space Mono',monospace;
  font-size:12px; font-weight:700; color:var(--text-2);
}
.tbar-pct { color:var(--accent); }

.tbar-hearts {
  display:flex; align-items:center; justify-content:center; gap:4px;
}

/* Progress bar */
.progress {
  width:100%; height:3px; border-radius:var(--r-p);
  overflow:hidden; background:rgba(255,255,255,0.06);
}
.progress-fill {
  height:100%;
  background:linear-gradient(90deg,var(--accent),var(--accent-2));
  border-radius:var(--r-p);
  transition:width .5s cubic-bezier(.25,.8,.25,1);
  position:relative; overflow:hidden;
}
.progress-fill::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.45) 50%,transparent 100%);
  background-size:200% 100%; animation:shimmer 2.5s infinite;
}

/* ─────────────────────────────────────────────
   CONTENT
   ───────────────────────────────────────────── */
.content {
  flex:1; min-height:0; padding:14px 12px;
  overflow-y:auto; overflow-x:hidden;
  -webkit-overflow-scrolling:touch;
}
.content::-webkit-scrollbar { width:2px; }
.content::-webkit-scrollbar-thumb { background:var(--glass-b); border-radius:2px; }

.content-inner,.bottombar-inner { width:100%; max-width:560px; margin:0 auto; }

/* ─────────────────────────────────────────────
   PUZZLE CARD
   ───────────────────────────────────────────── */
.puzzle-card {
  background:var(--glass); border:1px solid var(--glass-b);
  border-radius:var(--r-lg); padding:22px 14px 18px;
  backdrop-filter:blur(28px) saturate(1.4);
  -webkit-backdrop-filter:blur(28px) saturate(1.4);
  box-shadow:var(--sh-md), inset 0 1px 0 rgba(255,255,255,.07);
  position:relative; overflow:hidden;
}
.puzzle-card::before {
  content:''; position:absolute; top:0; left:12%; right:12%; height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.14),transparent);
}
.words-wrap { display:flex; flex-wrap:wrap; gap:10px 14px; justify-content:center; }
.word       { display:flex; gap:3px; }
.puzzle-scroll { max-height:100%; overflow-y:auto; overflow-x:hidden; }

/* ─────────────────────────────────────────────
   CELLS
   ───────────────────────────────────────────── */
.cell-wrap {
  display:flex; flex-direction:column; align-items:center; cursor:pointer;
}
.cell-wrap:hover .cell:not(.revealed):not(.win):not(.wrong):not(.selected) {
  border-color:rgba(108,142,255,.38);
  background:rgba(108,142,255,.07);
  transform:translateY(-1px);
}

.cell {
  width:34px; height:42px;
  display:flex; align-items:center; justify-content:center;
  font-family:'Space Mono',monospace;
  font-size:14px; font-weight:700;
  border-radius:var(--r-sm);
  background:var(--cell-bg);
  border:1.5px solid var(--cell-b);
  color:transparent;
  box-shadow:var(--sh-key);
  transition:border-color .15s, background .15s, box-shadow .15s, transform .12s;
}
.cell.selected {
  border-color:var(--accent);
  background:var(--accent-s);
  color:transparent;
  animation:pulseRing 2s ease-out infinite;
}
.cell.revealed,.cell.good,.cell.win {
  color:var(--green); background:var(--green-s); border-color:var(--green-b);
  box-shadow:0 0 14px rgba(45,212,160,.18), var(--sh-key);
}
.cell.wrong {
  color:var(--red); background:var(--red-s); border-color:var(--red-b);
  box-shadow:0 0 14px rgba(255,107,138,.22), var(--sh-key);
}
.cell-num {
  margin-top:3px;
  font-family:'Space Mono',monospace;
  font-size:8px; font-weight:700;
  color:var(--accent);
  opacity:0.55;
  text-shadow:0 0 6px var(--accent-g);
}

/* ─────────────────────────────────────────────
   BOTTOMBAR
   ───────────────────────────────────────────── */
.bottombar {
  flex-shrink:0;
  border-top:1px solid var(--glass-b);
  padding:0 0 calc(6px + env(safe-area-inset-bottom));
  background:rgba(6,7,26,0.82);
  backdrop-filter:blur(28px) saturate(1.5);
  -webkit-backdrop-filter:blur(28px) saturate(1.5);
  position:relative; z-index:2;
}
body.light .bottombar { background:rgba(237,240,255,.9); }

/* ─────────────────────────────────────────────
   HINT ROW
   ───────────────────────────────────────────── */
.hint-row {
  display:flex; justify-content:center; align-items:center;
  gap:8px; padding:7px 12px 4px; min-height:40px;
}

.hint-btn {
  display:inline-flex; align-items:center; justify-content:center;
  height:30px; padding:0 14px;
  border-radius:var(--r-sm);
  border:1px solid var(--amber-b);
  background:var(--amber-s); color:var(--amber);
  font-size:12px; font-weight:600;
  cursor:pointer; font-family:inherit; white-space:nowrap; gap:6px;
  transition:all .15s ease;
}
.hint-btn:hover:not(:disabled) {
  background:rgba(249,199,79,.18);
  box-shadow:0 0 18px rgba(249,199,79,.22);
  transform:translateY(-1px);
}
.hint-btn:active:not(:disabled) { transform:scale(.94); }
.hint-btn:disabled { opacity:.25; cursor:default; }
.hint-btn svg { flex-shrink:0; }

.hint-chip {
  display:inline-flex; align-items:center; justify-content:center;
  height:30px; padding:0 12px;
  font-family:'Space Mono',monospace;
  font-size:11px; font-weight:700;
  color:var(--accent); background:var(--accent-s);
  border:1px solid var(--accent-b);
  border-radius:var(--r-sm); letter-spacing:.5px; white-space:nowrap;
}

/* ─────────────────────────────────────────────
   KEYBOARD  (толық жаңа дизайн)
   ───────────────────────────────────────────── */
.keyboard {
  display:flex; flex-direction:column;
  align-items:center; gap:5px;
  padding:4px 6px 5px;
}
.key-row { display:flex; justify-content:center; gap:4px; }

.key {
  width:30px; height:42px;
  border-radius:var(--r-sm);
  border:1px solid var(--key-b);
  background:var(--key-bg);
  color:var(--key-text);
  font-family:'Space Grotesk',sans-serif;
  font-size:13px; font-weight:600;
  cursor:pointer;
  /* Физикалық батырма сезімі */
  box-shadow:var(--sh-key);
  transition:transform .1s cubic-bezier(.34,1.5,.64,1),
             background .1s, border-color .1s, box-shadow .1s;
  position:relative;
  /* Зум алдын алу */
  touch-action: manipulation;
  user-select: none;
  -webkit-user-select: none;
}
/* Жарықтық жоғарғы жиектен */
.key::before {
  content:'';
  position:absolute; top:0; left:10%; right:10%; height:1px;
  background:rgba(255,255,255,.09);
  border-radius:1px;
}
body.light .key::before { background:rgba(255,255,255,.85); }

.key:hover:not(:disabled) {
  background:rgba(108,142,255,.14);
  border-color:var(--accent-b);
  color:var(--text);
  transform:translateY(-3px);
  box-shadow:var(--sh-key), 0 6px 16px rgba(108,142,255,.18);
}
.key:active:not(:disabled) {
  transform:scale(.9) translateY(1px);
  box-shadow:0 1px 0 rgba(0,0,0,.65);
  background:var(--accent-s);
  border-color:var(--accent-b);
  color:var(--accent);
}
.key:disabled {
  opacity:.16; cursor:default;
  box-shadow:none;
}

/* ─────────────────────────────────────────────
   SETTINGS & BACK HEADER
   ───────────────────────────────────────────── */
.back-btn {
  width:34px; height:34px;
  border-radius:var(--r-sm); border:1px solid var(--glass-b);
  background:var(--glass); color:var(--text-2);
  cursor:pointer; font-size:16px;
  display:flex; align-items:center; justify-content:center;
  backdrop-filter:blur(8px); transition:all .15s ease;
}
.back-btn:hover  { background:var(--glass-h); color:var(--text); border-color:var(--accent-b); transform:translateX(-2px); }
.back-btn:active { transform:scale(.9); }

.setting-item {
  display:flex; justify-content:space-between; align-items:center;
  gap:16px; background:var(--glass); border:1px solid var(--glass-b);
  border-radius:var(--r-lg); padding:16px 18px;
  backdrop-filter:blur(16px); box-shadow:var(--sh-sm);
}
.setting-title { font-size:14px; font-weight:600; }
.setting-sub   { font-size:12px; color:var(--text-2); margin-top:2px; }

.switch {
  width:52px; height:28px; border:none; border-radius:var(--r-p);
  background:var(--text-3); position:relative; cursor:pointer;
  flex-shrink:0; transition:background .25s ease;
}
.switch.active { background:var(--accent); box-shadow:0 0 14px var(--accent-g); }
.switch-dot {
  width:22px; height:22px; border-radius:50%; background:#fff;
  position:absolute; top:3px; left:3px;
  display:flex; align-items:center; justify-content:center;
  font-size:11px; box-shadow:0 2px 6px rgba(0,0,0,.3);
  transition:left .25s cubic-bezier(.4,0,.2,1);
}
.switch.active .switch-dot { left:27px; }

/* ═══════════════════════════════════════════
   MODAL
   ═══════════════════════════════════════════ */
.modal {
  position: fixed; inset: 0;
  background: rgba(3,4,16,.92);
  backdrop-filter: blur(24px) saturate(1.3);
  -webkit-backdrop-filter: blur(24px) saturate(1.3);
  display: flex; align-items: center; justify-content: center;
  padding: 16px; z-index: 10;
  animation: fadeIn .18s ease;
}

.modal-card {
  width: 100%; max-width: 360px;
  background: var(--glass);
  border: 1px solid var(--glass-b);
  border-radius: var(--r-xl);
  padding: 0 0 24px;
  text-align: center;
  box-shadow: var(--sh-lg), inset 0 1px 0 rgba(255,255,255,.07);
  backdrop-filter: blur(36px) saturate(1.8);
  -webkit-backdrop-filter: blur(36px) saturate(1.8);
  animation: modalIn .28s cubic-bezier(.22,.68,0,1.2) forwards;
  overflow: hidden;
  position: relative;
}

/* Жоғарғы түрлі-түсті stripe */
.modal-stripe {
  height: 4px;
  width: 100%;
}
.modal-win  .modal-stripe { background: linear-gradient(90deg, var(--green), rgba(45,212,160,.3)); }
.modal-lose .modal-stripe { background: linear-gradient(90deg, var(--red),   rgba(255,107,138,.3)); }
.modal-done .modal-stripe { background: linear-gradient(90deg, var(--accent), rgba(167,139,250,.3)); }

/* Иконка */
.modal-icon-wrap {
  width: 72px; height: 72px;
  border-radius: 22px;
  margin: 28px auto 18px;
  display: flex; align-items: center; justify-content: center;
  position: relative;
}
.modal-icon-wrap svg { width: 34px; height: 34px; }

.modal-win  .modal-icon-wrap {
  background: var(--green-s); border: 1px solid var(--green-b);
  color: var(--green);
  box-shadow: 0 0 28px rgba(45,212,160,.2);
}
.modal-lose .modal-icon-wrap {
  background: var(--red-s); border: 1px solid var(--red-b);
  color: var(--red);
  box-shadow: 0 0 28px rgba(255,107,138,.2);
}
.modal-done .modal-icon-wrap {
  background: var(--accent-s); border: 1px solid var(--accent-b);
  color: var(--accent);
  box-shadow: 0 0 28px var(--accent-g);
}

/* Тақырып */
.modal-title {
  font-family: 'Space Mono', monospace;
  font-size: 20px; font-weight: 700;
  margin: 0 24px 8px; letter-spacing: .5px;
}
.modal-sub {
  font-size: 13px; color: var(--text-2);
  line-height: 1.7; margin: 0 24px 20px;
}

/* Дәйексөз блогы */
.modal-quote {
  margin: 0 20px 16px;
  padding: 16px;
  background: rgba(255,255,255,.025);
  border: 1px solid var(--glass-b);
  border-radius: var(--r-md);
  text-align: center;
  position: relative;
}
body.light .modal-quote { background: rgba(0,0,30,.03); }

.mq-bar {
  height: 2px; width: 32px;
  margin: 0 auto 12px;
  border-radius: 2px;
}
.modal-win  .mq-bar { background: var(--green); }
.modal-lose .mq-bar { background: var(--red); }
.modal-done .mq-bar { background: var(--accent); }

.mq-label {
  font-family: 'Space Mono', monospace;
  font-size: 9px; font-weight: 700;
  color: var(--text-3); letter-spacing: 2.5px;
  text-transform: uppercase; margin-bottom: 10px;
}
.mq-text {
  font-size: 13px; line-height: 1.85;
  font-weight: 600; color: var(--text);
  margin-bottom: 8px;
}
.mq-author {
  font-size: 11px; color: var(--text-2);
  font-style: italic;
}

/* Статистика торы */
.modal-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin: 0 20px 20px;
}
.mstat-cell {
  display: flex; flex-direction: column;
  align-items: center; gap: 4px;
  padding: 10px 4px;
  background: rgba(255,255,255,.02);
  border: 1px solid var(--glass-b);
  border-radius: var(--r-md);
}
body.light .mstat-cell { background: rgba(0,0,30,.025); }
.mstat-ico { display: flex; }
.mstat-ico svg { width: 15px; height: 15px; }
.mstat-val {
  font-family: 'Space Mono', monospace;
  font-size: 13px; font-weight: 700; color: var(--text);
}
.mstat-lbl {
  font-size: 9px; color: var(--text-3);
  letter-spacing: .5px; font-weight: 600;
}

/* Батырмалар */
.modal-btns {
  display: flex; flex-direction: column;
  gap: 8px; padding: 0 20px;
}

.modal-btn-main {
  width: 100%; height: 50px;
  border: none; border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  gap: 10px; cursor: pointer;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 15px; font-weight: 700;
  transition: transform .15s cubic-bezier(.34,1.4,.64,1), box-shadow .15s;
  position: relative; overflow: hidden;
}
.modal-btn-main::before {
  content: ''; position: absolute; top: 0; left: 12%; right: 12%; height: 1px;
  background: rgba(255,255,255,.2);
}
.modal-btn-main .mbtn-main-ico { display: flex; }
.modal-btn-main .mbtn-main-ico svg { width: 18px; height: 18px; }
.modal-btn-main:hover  { transform: translateY(-2px); }
.modal-btn-main:active { transform: scale(.97); }

.modal-btn-next {
  background: linear-gradient(135deg, var(--green) 0%, rgba(45,212,160,.7) 100%);
  color: #fff;
  box-shadow: var(--sh-grn);
}
.modal-btn-next:hover { box-shadow: 0 8px 28px rgba(45,212,160,.35); }

.modal-btn-retry {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  color: #fff;
  box-shadow: var(--sh-acc);
}
.modal-btn-retry:hover { box-shadow: 0 8px 28px var(--accent-g); }

.modal-done .modal-btn-main {
  background: linear-gradient(135deg, var(--accent) 0%, var(--accent-2) 100%);
  color: #fff;
  box-shadow: var(--sh-acc);
}

.modal-btn-sec {
  width: 100%; height: 44px;
  border: 1px solid var(--glass-b);
  border-radius: var(--r-md);
  background: var(--glass);
  color: var(--text-2);
  display: flex; align-items: center; justify-content: center;
  gap: 8px; cursor: pointer;
  font-family: 'Space Grotesk', sans-serif;
  font-size: 13px; font-weight: 600;
  backdrop-filter: blur(8px);
  transition: all .15s ease;
}
.modal-btn-sec svg { width: 15px; height: 15px; }
.modal-btn-sec:hover { background: var(--glass-h); color: var(--text); border-color: var(--accent-b); transform: translateY(-1px); }
.modal-btn-sec:active { transform: scale(.97); }

/* ─────────────────────────────────────────────
   MISC
   ───────────────────────────────────────────── */
.loading {
  min-height:100vh; display:flex; align-items:center; justify-content:center;
  color:var(--accent); font-family:'Space Mono',monospace;
  font-size:12px; letter-spacing:3px; text-transform:uppercase;
}

.badge {
  display:inline-flex; align-items:center; justify-content:center;
  font-family:'Space Mono',monospace; font-size:11px; font-weight:700;
  color:var(--accent); padding:4px 10px; border-radius:var(--r-sm);
  background:var(--accent-s); border:1px solid var(--accent-b);
}

/* ─────────────────────────────────────────────
   RESPONSIVE — narrow
   ───────────────────────────────────────────── */
@media (max-width: 390px) {
  .cell    { width:30px; height:38px; font-size:13px; }
  .key     { width:27px; height:38px; font-size:12px; }
  .key-row { gap:3px; }
  .words-wrap { gap:6px 8px; }
  .title-xl   { font-size:20px; letter-spacing:3px; }
  .tbar-row1  { grid-template-columns:32px 1fr 56px; }
  .tbar-row2  { grid-template-columns:70px 1fr 54px; }
  .tbar-stat-val { font-size:11px; }
  .level-dots    { max-width:170px; }
}

/* ─────────────────────────────────────────────
   RESPONSIVE — short screen
   ───────────────────────────────────────────── */
@media (max-height: 660px) {
  .topbar      { padding:6px 14px 6px; }
  .topbar-inner { gap:5px; }
  .content     { padding:10px; }
  .puzzle-card { padding:14px 10px 12px; }
  .words-wrap  { gap:6px 8px; }
  .keyboard    { gap:3px; padding:2px 4px 4px; }
  .key         { height:36px; }
  .cell        { height:37px; }
  .hint-row    { padding:4px 12px 3px; min-height:34px; }
  .hint-btn,.hint-chip { height:26px; font-size:11px; }
  .logo        { font-size:42px; }
  .lvl-dot     { width:4px; height:4px; }
}

/* ═══════════════════════════════════════════
   MENU SCREEN
   ═══════════════════════════════════════════ */

.menu-screen {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 20px;
  overflow-y: auto;
}

.menu-wrap {
  width: 100%;
  max-width: 340px;
  display: flex;
  flex-direction: column;
  gap: 28px;
  animation: cardIn .4s cubic-bezier(.25,.8,.25,1) both;
}

/* ── Hero ── */
.menu-hero {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  text-align: center;
}

.menu-logo-box {
  width: 72px; height: 72px;
  border-radius: 22px;
  background: var(--accent-s);
  border: 1px solid var(--accent-b);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent);
  box-shadow: 0 0 32px var(--accent-g), inset 0 1px 0 rgba(255,255,255,.1);
  animation: float 5s ease-in-out infinite;
}
.menu-logo-box svg {
  width: 34px; height: 34px;
}

.menu-title {
  font-family: 'Space Mono', monospace;
  font-size: 22px; font-weight: 700;
  letter-spacing: 4px; text-transform: uppercase;
  margin: 0;
  background: linear-gradient(130deg, var(--text) 30%, var(--accent));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.menu-sub {
  font-size: 13px; color: var(--text-2);
  margin: 0; line-height: 1.6;
}

/* ── Main buttons ── */
.menu-btns {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.menu-btn {
  width: 100%;
  display: flex; align-items: center;
  gap: 14px;
  padding: 14px 16px;
  border: 1px solid var(--glass-b);
  border-radius: 18px;
  background: var(--glass);
  cursor: pointer;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  transition: transform .15s cubic-bezier(.34,1.4,.64,1),
              box-shadow .15s ease,
              border-color .15s, background .15s;
  position: relative; overflow: hidden;
  text-align: left;
}
.menu-btn::before {
  content: '';
  position: absolute; top: 0; left: 12%; right: 12%; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.14), transparent);
}
.menu-btn:hover  { background: var(--glass-h); transform: translateY(-2px); }
.menu-btn:active { transform: scale(.97); }

.menu-btn-primary {
  border-color: var(--accent-b);
  background: var(--accent-s);
  box-shadow: var(--sh-acc);
}
.menu-btn-primary:hover {
  background: rgba(108,142,255,.18);
  box-shadow: 0 8px 28px var(--accent-g);
}

.menu-btn-continue {
  border-color: var(--green-b);
  background: var(--green-s);
  box-shadow: var(--sh-grn);
}
.menu-btn-continue:hover {
  background: rgba(45,212,160,.16);
}

/* Icon circle */
.mbtn-icon {
  width: 40px; height: 40px; border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.mbtn-icon svg { width: 18px; height: 18px; }

.mbtn-icon-accent {
  background: var(--accent-s);
  border: 1px solid var(--accent-b);
  color: var(--accent);
  box-shadow: 0 0 12px var(--accent-g);
}
.mbtn-icon-green {
  background: var(--green-s);
  border: 1px solid var(--green-b);
  color: var(--green);
  box-shadow: 0 0 12px rgba(45,212,160,.2);
}

/* Text */
.mbtn-body {
  flex: 1;
  display: flex; flex-direction: column; gap: 2px;
}
.mbtn-label {
  font-size: 15px; font-weight: 700; color: var(--text);
  display: block;
}
.mbtn-hint {
  font-family: 'Space Mono', monospace;
  font-size: 10px; color: var(--text-2);
  display: block; letter-spacing: .3px;
}

/* Chevron */
.mbtn-chev {
  width: 20px; color: var(--text-3);
  display: flex; align-items: center;
  transition: transform .15s ease, color .15s;
}
.mbtn-chev svg { width: 16px; height: 16px; }
.menu-btn:hover .mbtn-chev { transform: translateX(3px); color: var(--text-2); }

/* ── Row 2: small buttons ── */
.menu-row2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

.menu-btn-sm {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 8px;
  padding: 16px 10px;
  border: 1px solid var(--glass-b);
  border-radius: 18px;
  background: var(--glass);
  cursor: pointer;
  backdrop-filter: blur(16px);
  transition: transform .15s cubic-bezier(.34,1.4,.64,1),
              background .15s, border-color .15s;
}
.menu-btn-sm:hover  { background: var(--glass-h); border-color: var(--accent-b); transform: translateY(-2px); }
.menu-btn-sm:active { transform: scale(.95); }

.mbtn-sm-ico {
  width: 36px; height: 36px; border-radius: 10px;
  background: var(--glass-h); border: 1px solid var(--glass-b);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-2);
}
.mbtn-sm-ico svg { width: 16px; height: 16px; }
.menu-btn-sm:hover .mbtn-sm-ico { color: var(--accent); border-color: var(--accent-b); }

.mbtn-sm-lbl {
  font-size: 12px; font-weight: 600; color: var(--text-2);
  transition: color .15s;
}
.menu-btn-sm:hover .mbtn-sm-lbl { color: var(--text); }

/* ═══════════════════════════════════════════
   ABOUT SCREEN
   ═══════════════════════════════════════════ */

.about-rules {
  display: flex; flex-direction: column; gap: 4px;
}

.about-rule {
  display: flex; align-items: flex-start; gap: 14px;
  padding: 12px 14px;
  border-radius: var(--r-md);
  background: rgba(255,255,255,.025);
  border: 1px solid var(--glass-b);
  transition: background .15s;
}
body.light .about-rule { background: rgba(0,0,30,.025); }
.about-rule:hover { background: var(--glass-h); }

.about-rule-ico {
  width: 32px; height: 32px; border-radius: 9px;
  background: var(--accent-s); border: 1px solid var(--accent-b);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent); flex-shrink: 0;
  margin-top: 1px;
}
.about-rule-ico svg { width: 15px; height: 15px; }

.about-rule-txt {
  font-size: 13px; font-weight: 500;
  color: var(--text-2); line-height: 1.6;
  padding-top: 6px;
}

.about-ver {
  font-family: 'Space Mono', monospace;
  font-size: 10px; color: var(--text-3);
  text-align: center; letter-spacing: 2px;
  margin-top: 16px;
}