/* Basic reset */
* {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
  }
  
  body {
    font-family: sans-serif;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    padding: 1rem;
    background-color: #f3f3f3;
  }
  
  /* Title */
  h1 {
    margin: 1rem 0;
    text-align: center;
  }
  
  /* Grid styling */
  #grid-container {
    display: grid;
    grid-template-rows: repeat(6, 1fr);
    gap: 0.5rem;
    margin-bottom: 1rem;
  }
  
  .row {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0.5rem;
  }
  
  .cell {
    width: 3rem;
    height: 3rem;
    border: 2px solid #999;
    border-radius: 4px;
    background-color: white;
    font-size: 1.5rem;
    font-weight: bold;
    text-align: center;
    line-height: 3rem;
    text-transform: uppercase;
    cursor: pointer;
  }
  
  /* Color states */
  .gray {
    background-color: #787c7e; /* Wordle's gray */
    color: white;
  }
  
  .yellow {
    background-color: #c9b458; /* Wordle's yellow */
    color: white;
  }
  
  .green {
    background-color: #6aaa64; /* Wordle's green */
    color: white;
  }
  
  /* On-screen keyboard */
  #keyboard-container {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 1rem;
  }
  
  .key-row {
    display: flex;
    gap: 0.3rem;
    margin-bottom: 0.3rem;
  }
  
  .key {
    min-width: 2rem;
    padding: 0.5rem 0.6rem;
    border: 1px solid #333;
    border-radius: 4px;
    background-color: #d4d4d4;
    font-size: 1rem;
    font-weight: bold;
    cursor: pointer;
    text-transform: uppercase;
  }
  
  .key.gray {
    background-color: #787c7e;
    color: #fff;
  }
  
  .key.yellow {
    background-color: #c9b458;
    color: #fff;
  }
  
  .key.green {
    background-color: #6aaa64;
    color: #fff;
  }
  
  /* Stats and buttons */
  #stats-container {
    margin-top: 1rem;
    text-align: center;
  }
  
  #buttons-container {
    display: flex;
    gap: 1rem;
    margin-top: 1rem;
  }
  
  button {
    padding: 0.6rem 1rem;
    font-size: 1rem;
    font-weight: bold;
    cursor: pointer;
    border: 2px solid #444;
    border-radius: 4px;
    background-color: #fff;
  }
  
  /* Mobile responsiveness */
  @media (max-width: 600px) {
    .cell {
      width: 2.4rem;
      height: 2.4rem;
      line-height: 2.4rem;
      font-size: 1.2rem;
    }
  
    .key {
      min-width: 1.5rem;
      padding: 0.4rem 0.5rem;
      font-size: 0.9rem;
    }
  
    button {
      padding: 0.4rem 0.8rem;
      font-size: 0.9rem;
    }
  }
  