:root{
  --btn-size: 84px;
  --btn-bg: #111;
  --btn-color: #fff;
  --neon-pink: #ff4de2;
  --neon-cyan: #00ffff;
  --neon-purple: #9d4edd;
  --neon-green: #00ff88;
  --neon-blue: #0066ff;
  --dark-bg: #0a0a0a;
  --glow-intensity: 0 0 20px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family: "Calistoga", "Noto Sans", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background: radial-gradient(circle at center, #1a0033 0%, var(--dark-bg) 100%);
  color: #fff;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow: hidden;
}

.wrap{
  display:flex;
  align-items:center;
  justify-content:center;
  width:100%;
  padding:32px;
  position:relative;
}

.main-buttons-container {
  display: flex;
  gap: 40px; /* Space between P and L buttons */
  align-items: center;
  justify-content: center;
}

/* Neon-styled button with glowing effects */
.letter-btn{
  width:var(--btn-size);
  height:var(--btn-size);
  border-radius:999px;
  border:2px solid var(--neon-cyan);
  background: linear-gradient(135deg, rgba(0,255,255,0.1) 0%, rgba(157,78,221,0.2) 100%);
  color:var(--neon-cyan);
  font-size:44px;
  line-height:1;
  display:grid;
  place-items:center;
  cursor:pointer;
  transition: all .12s ease;
  box-shadow: 
    var(--glow-intensity) var(--neon-cyan),
    inset 0 0 20px rgba(0,255,255,0.1);
  text-shadow: 0 0 10px var(--neon-cyan);
  backdrop-filter: blur(10px);
}

.letter-btn:hover{ 
  transform: translateY(-3px) scale(1.05); 
  box-shadow: 
    0 10px 30px rgba(0,255,255,0.4),
    var(--glow-intensity) var(--neon-cyan),
    inset 0 0 30px rgba(0,255,255,0.2);
  border-color: #fff;
  text-shadow: 0 0 20px #fff;
}
.letter-btn:active{ 
  transform: translateY(0) scale(0.98); 
  box-shadow: 
    var(--glow-intensity) var(--neon-cyan),
    inset 0 0 40px rgba(0,255,255,0.3);
}
.letter-btn:focus{ 
  outline:3px solid var(--neon-pink); 
  outline-offset:4px; 
  box-shadow: 
    var(--glow-intensity) var(--neon-pink),
    var(--glow-intensity) var(--neon-cyan);
}

/* Generator Button specific styling (can share general letter-btn look) */
.generator-btn {
  color: var(--neon-purple);
  border-color: var(--neon-purple);
  box-shadow: 
    var(--glow-intensity) var(--neon-purple),
    inset 0 0 20px rgba(157,78,221,0.1);
  text-shadow: 0 0 10px var(--neon-purple);
}

.generator-btn:hover {
  box-shadow: 
    0 10px 30px rgba(157, 78, 221, 0.4),
    var(--glow-intensity) var(--neon-purple),
    inset 0 0 30px rgba(157, 78, 221, 0.2);
  border-color: #fff;
  text-shadow: 0 0 20px #fff;
}

/* Neon menu styling */
.menu{
  position:absolute;
  min-width:180px;
  background: rgba(0,0,0,0.9);
  border:2px solid var(--neon-purple);
  box-shadow:
    0 0 40px rgba(157,78,221,0.6),
    inset 0 0 30px rgba(157,78,221,0.1);
  border-radius:12px;
  padding:12px;
  display:none;
  gap:8px;
  flex-direction:column;
  z-index:40;
  backdrop-filter: blur(20px);
}

/* Level Generator menu specific styling */
.level-generator-menu {
  min-width: 300px;
  max-height: 80vh;
  overflow-y: auto;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  border: 2px solid var(--neon-pink);
  box-shadow:
    0 0 40px rgba(255,77,226,0.6),
    inset 0 0 30px rgba(255,77,226,0.1);
}

.generator-info {
  font-size: 0.9rem;
  color: var(--neon-green);
  margin-bottom: 12px;
  text-align: center;
}

.upload-label {
  display: block;
  text-align: center;
  margin-bottom: 12px;
  cursor: pointer;
  background: rgba(157, 78, 221, 0.1);
  border-color: var(--neon-purple);
  color: var(--neon-purple);
  padding: 12px 16px;
  border-radius: 8px;
  font-weight: 600;
  transition: all 0.2s ease;
  text-shadow: 0 0 5px var(--neon-purple);
}

.upload-label:hover {
  background: rgba(157, 78, 221, 0.3);
  box-shadow: var(--glow-intensity) var(--neon-purple);
  transform: translateY(-2px);
}

.generator-status {
  text-align: center;
  margin-bottom: 16px;
  color: var(--neon-cyan);
  font-size: 0.9rem;
  min-height: 1.2rem;
}

.custom-level-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 12px;
  border-radius: 6px;
  margin-bottom: 6px;
  border: 1px solid rgba(0,255,136, 0.1);
  background: rgba(0, 0, 0, 0.3);
}

.custom-level-item:hover {
  background: rgba(0,255,136, 0.1);
  box-shadow: 0 0 5px var(--neon-green);
}

.level-name {
  color: var(--neon-green);
  text-shadow: 0 0 3px var(--neon-green);
  font-size: 0.95rem;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  max-width: 60%;
}

.level-actions {
    display: flex;
    gap: 6px;
    align-items: center;
}

.level-actions button {
    padding: 6px 10px;
    font-size: 0.8rem;
    min-width: auto;
}

.level-actions button.export-btn {
    background: rgba(0,255,136,0.1);
    border-color: var(--neon-green);
    color: var(--neon-green);
    font-size: 0.75rem;
    padding: 4px 8px;
    min-width: auto;
}

.level-actions button.export-btn:hover {
    background: rgba(0,255,136,0.3);
    box-shadow: var(--glow-intensity) var(--neon-green);
}

/* Ensure the level items use the menu-item style template */
.custom-level-item button.mode-btn {
    padding: 6px 10px;
    font-size: 0.8rem;
}
.custom-level-item button.delete-btn {
    background: rgba(255, 77, 226, 0.1);
    border-color: var(--neon-pink);
    color: var(--neon-pink);
}

.custom-level-item button.delete-btn:hover {
    background: rgba(255, 77, 226, 0.3);
    box-shadow: var(--glow-intensity) var(--neon-pink);
}

.export-import-container {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px solid rgba(157, 78, 221, 0.3);
}

.export-import-container .upload-label {
    margin-bottom: 12px;
    font-size: 0.85rem;
    padding: 12px 16px;
}

.export-import-container .mode-btn {
    font-size: 0.85rem;
    padding: 12px 16px;
    background: rgba(0,255,136,0.1);
    border-color: var(--neon-green);
    color: var(--neon-green);
    text-shadow: 0 0 5px var(--neon-green);
}

.export-import-container .mode-btn:hover {
    background: rgba(0,255,136,0.3);
    box-shadow: var(--glow-intensity) var(--neon-green);
    transform: translateY(-2px);
}

/* Mode selector neon styling */
.mode-selector { 
  min-width:240px; 
  padding:16px; 
  text-align:center; 
  gap:12px;
  border:2px solid var(--neon-pink);
  box-shadow:
    0 0 40px rgba(255,77,226,0.6),
    inset 0 0 30px rgba(255,77,226,0.1);
}
.mode-title { 
  font-weight:700; 
  margin-bottom:8px; 
  color: var(--neon-pink);
  text-shadow: 0 0 10px var(--neon-pink);
  font-size: 1.2rem;
}
.mode-options { display:flex; gap:8px; justify-content:center; margin-bottom:12px; flex-wrap:wrap; }
.mode-btn { 
  padding:12px 16px; 
  border-radius:8px; 
  border:2px solid var(--neon-cyan); 
  cursor:pointer; 
  background: rgba(0,255,255,0.1);
  color: var(--neon-cyan);
  font-weight: 600;
  transition: all 0.2s ease;
  text-shadow: 0 0 5px var(--neon-cyan);
}
.mode-btn:hover {
  background: rgba(0,255,255,0.3);
  box-shadow: var(--glow-intensity) var(--neon-cyan);
  transform: translateY(-2px);
}
.mode-cancel { 
  background:transparent; 
  border:0; 
  color:var(--neon-purple); 
  cursor:pointer; 
  padding:8px;
  transition: all 0.2s ease;
}
.mode-cancel:hover {
  color: #fff;
  text-shadow: 0 0 10px var(--neon-purple);
}
.mode-toggle { 
  font-size: 0.95rem; 
  color: var(--neon-green);
  display:flex; 
  justify-content:center; 
  text-shadow: 0 0 5px var(--neon-green);
}

/* visible state */
.menu.show{ display:flex; }

/* Neon menu items */
.menu-item{
  background:transparent;
  border:0;
  text-align:left;
  padding:12px 16px;
  border-radius:8px;
  cursor:pointer;
  font-family:inherit;
  color: var(--neon-green);
  border:1px solid transparent;
  transition: all 0.2s ease;
  text-shadow: 0 0 5px var(--neon-green);
}
.menu-item:hover, .menu-item:focus{
  background: rgba(0,255,136,0.1);
  border-color: var(--neon-green);
  box-shadow: var(--glow-intensity) var(--neon-green);
  text-shadow: 0 0 15px var(--neon-green);
  outline: none;
}

/* Neon playing state */
body.playing {
  background: radial-gradient(circle at center, #2a0055 0%, #000 100%);
  color: #fff;
  cursor: none;
  animation: pulse-bg 2s ease-in-out infinite alternate;
}

@keyframes pulse-bg {
  0% { background: radial-gradient(circle at center, #2a0055 0%, #000 100%); }
  100% { background: radial-gradient(circle at center, #1a0033 0%, #000 100%); }
}

/* Neon custom cursor */
.custom-cursor{
  position:fixed;
  top:0; left:0;
  width:20px; height:20px;
  border-radius:50%;
  pointer-events:none;
  transform:translate(-50%,-50%) scale(1);
  mix-blend-mode:screen;
  filter:blur(0.6px);
  box-shadow: 
    0 0 20px var(--neon-pink), 
    0 0 40px var(--neon-green), 
    0 0 60px var(--neon-cyan),
    inset 0 0 10px #fff;
  transition: transform .12s ease, opacity .12s ease;
  opacity:0;
  z-index:9999;
}
/* visible when playing */
body.playing .custom-cursor{ 
  opacity:1; 
  transform:translate(-50%,-50%) scale(1); 
  animation: cursor-pulse 1s ease-in-out infinite alternate;
}

@keyframes cursor-pulse {
  0% { box-shadow: 0 0 20px var(--neon-pink), 0 0 40px var(--neon-green), 0 0 60px var(--neon-cyan), inset 0 0 10px #fff; }
  100% { box-shadow: 0 0 30px var(--neon-pink), 0 0 50px var(--neon-green), 0 0 70px var(--neon-cyan), inset 0 0 15px #fff; }
}

/* Neon animated hollow circle */
.beat-circle{
  position:fixed;
  border-radius:50%;
  border: 3px solid rgba(255,255,255,0.95);
  box-shadow: 
    0 0 30px var(--neon-pink),
    0 0 60px var(--neon-cyan),
    inset 0 0 20px rgba(255,77,226,0.3);
  transform: translate(-50%,-50%) scale(0.4);
  pointer-events: none;
  z-index: 9998;
  opacity: 0.95;
  animation: beat-pop 900ms cubic-bezier(.2,.9,.2,1);
  backdrop-filter: blur(2px);
}

@keyframes beat-pop {
  0% { 
    transform: translate(-50%,-50%) scale(0.4); 
    opacity: 0.9; 
    box-shadow: 0 0 20px var(--neon-pink), 0 0 40px var(--neon-cyan);
  }
  30% { 
    transform: translate(-50%,-50%) scale(1.05); 
    opacity: 0.95; 
    box-shadow: 0 0 40px var(--neon-pink), 0 0 80px var(--neon-cyan);
  }
  100% { 
    transform: translate(-50%,-50%) scale(1.8); 
    opacity: 0; 
    box-shadow: 0 0 60px var(--neon-pink), 0 0 120px var(--neon-cyan);
  }
}

/* Neon game over screen */
.game-over-screen {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.95);
  color: white;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  z-index: 10000;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease;
  font-family: "Calistoga", "Noto Sans", system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  backdrop-filter: blur(10px);
}

.game-over-screen[aria-hidden="false"] {
  opacity: 1;
  visibility: visible;
}

.game-over-screen h1 {
  font-size: 5rem;
  margin-bottom: 20px;
  color: var(--neon-pink);
  text-shadow: 
    0 0 20px var(--neon-pink),
    0 0 40px var(--neon-pink);
  animation: flicker 2s infinite alternate;
}

@keyframes flicker {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.8; }
}

.game-over-screen p {
  font-size: 1.8rem;
  margin-bottom: 40px;
  color: var(--neon-cyan);
  text-shadow: 0 0 10px var(--neon-cyan);
}

#restartBtn {
  padding: 20px 40px;
  font-size: 1.4rem;
  background: linear-gradient(135deg, var(--neon-pink) 0%, var(--neon-purple) 100%);
  color: #fff;
  border: 2px solid var(--neon-pink);
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  text-shadow: 0 0 10px rgba(255,255,255,0.8);
  box-shadow: 
    0 0 30px rgba(255,77,226,0.5),
    inset 0 0 20px rgba(255,255,255,0.1);
}

#restartBtn:hover {
  background: linear-gradient(135deg, #ff6bf0 0%, #b56af0 100%);
  box-shadow: 
    0 0 50px rgba(255,77,226,0.8),
    inset 0 0 30px rgba(255,255,255,0.2);
  transform: translateY(-3px) scale(1.05);
}

#restartBtn:active {
  transform: translateY(0) scale(0.98);
}

/* Hide everything except neon elements when playing */
body.playing > :not(.custom-cursor):not(.beat-circle):not(.game-over-screen):not(.wrap) {
  visibility: hidden;
  pointer-events: none;
  user-select: none;
}

/* Neon glow for wrap during gameplay */
body.playing .wrap {
  filter: drop-shadow(0 0 20px var(--neon-cyan));
}

/* Settings button */
.settings-btn {
  position: fixed;
  top: 20px;
  right: 20px;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 2px solid var(--neon-purple);
  background: rgba(0, 0, 0, 0.8);
  color: var(--neon-purple);
  font-size: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
  backdrop-filter: blur(10px);
  box-shadow: var(--glow-intensity) var(--neon-purple);
  text-shadow: 0 0 10px var(--neon-purple);
  z-index: 50;
}

.settings-btn:hover {
  background: rgba(157, 78, 221, 0.2);
  box-shadow: 0 0 30px var(--neon-purple);
  transform: translateY(-2px) scale(1.05);
}

.settings-btn:active {
  transform: translateY(0) scale(0.98);
}

/* Settings menu */
.settings-menu {
  position: fixed;
  top: 80px;
  right: 20px;
  min-width: 200px;
  border: 2px solid var(--neon-purple);
  box-shadow: 0 0 40px rgba(157, 78, 221, 0.6);
}

.settings-title {
  font-weight: 700;
  margin-bottom: 12px;
  color: var(--neon-purple);
  text-shadow: 0 0 10px var(--neon-purple);
  font-size: 1.1rem;
}

.settings-options {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.volume-control {
  margin-top: 8px;
}

.volume-label {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--neon-cyan);
  text-shadow: 0 0 5px var(--neon-cyan);
  font-size: 0.95rem;
}

#volumeSlider {
  width: 120px;
  height: 6px;
  background: rgba(0,255,255,0.2);
  border-radius: 3px;
  outline: none;
  -webkit-appearance: none;
  cursor: pointer;
}

#volumeSlider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--neon-cyan);
  box-shadow: var(--glow-intensity) var(--neon-cyan);
  cursor: pointer;
}

#volumeSlider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--neon-cyan);
  box-shadow: var(--glow-intensity) var(--neon-cyan);
  cursor: pointer;
  border: none;
}

.volume-value {
  font-weight: 700;
  color: var(--neon-pink);
  text-shadow: 0 0 10px var(--neon-pink);
  min-width: 30px;
  text-align: right;
}

/* Keystrokes display */
.keystrokes-display {
  position: fixed;
  top: 20px;
  left: 20px;
  background: rgba(0, 0, 0, 0.8);
  border: 2px solid var(--neon-cyan);
  border-radius: 12px;
  padding: 16px;
  min-width: 120px;
  backdrop-filter: blur(20px);
  box-shadow: var(--glow-intensity) var(--neon-cyan);
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
}

.keystrokes-display.show {
  opacity: 1;
  visibility: visible;
}

.keystroke-stats {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.stat-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: var(--neon-cyan);
  text-shadow: 0 0 5px var(--neon-cyan);
}

.stat-label {
  font-weight: 600;
  font-size: 0.9rem;
}

.stat-value {
  font-weight: 700;
  font-size: 1.1rem;
  color: var(--neon-pink);
  text-shadow: 0 0 10px var(--neon-pink);
}

/* Click indicator */
.click-indicator {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  border: 3px solid var(--neon-green);
  transform: translate(-50%, -50%) scale(0);
  opacity: 0;
  pointer-events: none;
  transition: all 0.2s ease;
}

.click-indicator.active {
  transform: translate(-50%, -50%) scale(1);
  opacity: 1;
  animation: click-pulse 0.3s ease-out;
}

@keyframes click-pulse {
  0% {
    transform: translate(-50%, -50%) scale(0);
    opacity: 1;
    box-shadow: var(--glow-intensity) var(--neon-green);
  }
  50% {
    transform: translate(-50%, -50%) scale(1.2);
    opacity: 0.8;
    box-shadow: 0 0 40px var(--neon-green), 0 0 80px var(--neon-green);
  }
  100% {
    transform: translate(-50%, -50%) scale(1.5);
    opacity: 0;
    box-shadow: 0 0 60px var(--neon-green);
  }
}

/* Hide settings button during gameplay */
body.playing .settings-btn {
  opacity: 0;
  pointer-events: none;
}

.toggle-label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  color: var(--neon-green);
  text-shadow: 0 0 5px var(--neon-green);
  font-size: 0.95rem;
}

.toggle-label input[type="checkbox"] {
  appearance: none;
  width: 40px;
  height: 20px;
  border: 2px solid var(--neon-green);
  border-radius: 999px;
  position: relative;
  background: rgba(0,255,136,0.1);
  transition: all 0.2s ease;
}

.toggle-label input[type="checkbox"]:checked {
  background: var(--neon-green);
  box-shadow: var(--glow-intensity) var(--neon-green);
}

.toggle-label input[type="checkbox"]::before {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  background: var(--neon-green);
  border-radius: 50%;
  transition: transform 0.2s ease;
}

.toggle-label input[type="checkbox"]:checked::before {
  transform: translateX(20px);
  background: #000;
}

.toggle-text {
  user-select: none;
}

/* Cheat menu styles */
.cheat-menu {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  min-width: 280px;
  border: 2px solid var(--neon-pink);
  box-shadow: 
    0 0 40px rgba(255,77,226,0.6),
    inset 0 0 30px rgba(255,77,226,0.1);
  z-index: 10001;
}

.cheat-title {
  font-weight: 700;
  margin-bottom: 16px;
  color: var(--neon-pink);
  text-shadow: 0 0 10px var(--neon-pink);
  font-size: 1.3rem;
  text-align: center;
}

.cheat-options {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cheat-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cheat-speed-label {
  display: flex;
  align-items: center;
  gap: 12px;
  color: var(--neon-cyan);
  text-shadow: 0 0 5px var(--neon-cyan);
  font-size: 0.95rem;
}

#customSpeedInput {
  width: 80px;
  padding: 8px 12px;
  background: rgba(0,255,255,0.1);
  border: 2px solid var(--neon-cyan);
  border-radius: 6px;
  color: var(--neon-cyan);
  text-shadow: 0 0 5px var(--neon-cyan);
  font-family: inherit;
  font-size: 1rem;
}

#customSpeedInput:focus {
  outline: none;
  box-shadow: var(--glow-intensity) var(--neon-cyan);
  background: rgba(0,255,255,0.2);
}

#applySpeedBtn {
  padding: 8px 16px;
  font-size: 0.9rem;
  min-width: 60px;
}

.tutorial-btn {
  background: rgba(157, 78, 221, 0.2);
  border: 2px solid var(--neon-purple);
  color: var(--neon-purple);
  padding: 12px 16px;
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 600;
  transition: all 0.3s ease;
  text-shadow: 0 0 5px var(--neon-purple);
  margin-top: 8px;
}

.tutorial-btn:hover {
  background: rgba(157, 78, 221, 0.4);
  box-shadow: var(--glow-intensity) var(--neon-purple);
  transform: translateY(-2px);
}

.tutorial-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 20000;
  opacity: 0;
  visibility: hidden;
  transition: all 0.3s ease;
  backdrop-filter: blur(10px);
}

.tutorial-modal.show {
  opacity: 1;
  visibility: visible;
}

.tutorial-content {
  background: rgba(0, 0, 0, 0.95);
  border: 2px solid var(--neon-cyan);
  border-radius: 16px;
  padding: 32px;
  max-width: 500px;
  max-height: 80vh;
  overflow-y: auto;
  box-shadow: 
    0 0 60px rgba(0,255,255,0.6),
    inset 0 0 30px rgba(0,255,255,0.1);
  backdrop-filter: blur(20px);
}

.tutorial-title {
  color: var(--neon-cyan);
  font-size: 2rem;
  margin-bottom: 24px;
  text-align: center;
  text-shadow: 0 0 20px var(--neon-cyan);
}

.tutorial-text {
  color: #fff;
  line-height: 1.6;
}

.tutorial-text h3 {
  color: var(--neon-pink);
  margin: 20px 0 12px 0;
  font-size: 1.2rem;
  text-shadow: 0 0 10px var(--neon-pink);
}

.tutorial-text p {
  margin-bottom: 16px;
  color: var(--neon-green);
  text-shadow: 0 0 5px var(--neon-green);
}

.tutorial-text ul {
  list-style: none;
  padding-left: 0;
}

.tutorial-text li {
  margin-bottom: 8px;
  padding-left: 20px;
  position: relative;
  color: var(--neon-cyan);
  text-shadow: 0 0 5px var(--neon-cyan);
}

.tutorial-text li:before {
  content: "▸";
  position: absolute;
  left: 0;
  color: var(--neon-purple);
  text-shadow: 0 0 5px var(--neon-purple);
}

.tutorial-text strong {
  color: var(--neon-pink);
  text-shadow: 0 0 5px var(--neon-pink);
}

.tutorial-close {
  background: linear-gradient(135deg, var(--neon-cyan) 0%, var(--neon-blue) 100%);
  border: 2px solid var(--neon-cyan);
  color: #000;
  padding: 12px 24px;
  border-radius: 8px;
  cursor: pointer;
  font-family: inherit;
  font-size: 1rem;
  font-weight: 700;
  transition: all 0.3s ease;
  text-shadow: 0 0 5px rgba(0,255,255,0.5);
  box-shadow: var(--glow-intensity) var(--neon-cyan);
  margin-top: 24px;
  width: 100%;
}

.tutorial-close:hover {
  background: linear-gradient(135deg, #00ffff 0%, #0088ff 100%);
  box-shadow: 0 0 30px var(--neon-cyan);
  transform: translateY(-2px);
}

/* Hide tutorial during gameplay */
body.playing .tutorial-modal {
  display: none;
}

.keybinds { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.key-btn { min-width:84px; }
.key-btn.mode-btn { background: rgba(0,255,255,0.1); }

/* Hide other UI elements when level select menu is open */
body:has(#pMenu.show) .settings-btn,
body:has(#pMenu.show) .generator-btn,
body:has(#modeSelector.show) .settings-btn,
body:has(#modeSelector.show) .generator-btn,
body:has(#generatorMenu.show) .settings-btn,
body:has(#generatorMenu.show) .letter-btn:not(.generator-btn),
body:has(#settingsMenu.show) .letter-btn,
body:has(#tutorialModal.show) .letter-btn,
body:has(#tutorialModal.show) .settings-btn {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

/* Hide main buttons container when any menu is open */
body:has(#pMenu.show) .main-buttons-container,
body:has(#modeSelector.show) .main-buttons-container,
body:has(#generatorMenu.show) .main-buttons-container,
body:has(#settingsMenu.show) .main-buttons-container,
body:has(#tutorialModal.show) .main-buttons-container {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s ease;
}