#calendar-container {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
}

.month-header {
  font-weight: normal;
  font-size: 1.2em; /* 月のフォントサイズを小さめに */
  text-align: left; /* 左に配置 */
}

#calendar {
  display: grid;
  grid-template-columns: repeat(7, 1fr); /* 7列（1週間） */
  gap: 1px;
  background-color: #f0f0f0;
  padding: 10px;
  max-width: 100%;
  box-sizing: border-box;
  border: magenta solid 1px;
  border-radius: 10px;
}

#calendar div {
  padding: 10px;
  text-align: center;
  background-color: #fff;
  box-sizing: border-box;
}

.header {
  font-weight: bold;
  background-color: #d3d3d3;
}

.weekend {
  color: red;
  background-color: #fdd !important; /* 日曜と土曜の背景色を赤く */
}

.empty {
  background-color: #f0f0f0;
}

/* レスポンシブ対応: スマートフォンなどの小さい画面では文字サイズとレイアウトを調整 */
@media (max-width: 600px) {
  #calendar {
    grid-template-columns: repeat(7, 1fr); /* 7列のまま */
  }

  #calendar div {
    padding: 5px; /* パディングを小さくしてセルのサイズを縮小 */
    font-size: 12px; /* 文字サイズを小さく */
  }

  .weekend {
    background-color: #ffcccc !important; /* 小さい画面用に背景色を明るめに */
  }
}

